• 不妨默认将对象升序排序

1. 冒泡排序 BubbleSort

1.1 算法描述

  1. 从前向后,依次比较相邻的元素,若前一个比后一个大,就对它俩做交换
  2. 对每一对相邻元素作同样的工作,从头一对到最后一对
  3. 做完一轮后,最后的元素就是最大的数
  4. 针对所有的元素重复以上的步骤,除了最后排完序的
  5. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较

1.2 性能分析

  • 最优时间复杂度:O(n)

    • 表示遍历一次发现没有任何可以交换的元素,排序结束
  • 最坏时间复杂度:0(n2)

  • 稳定性:稳定

1.3 Python 代码实现

from random import randrange

def bubble_sort(lst):
for j in range(len(lst)-1, 0, -1):
for i in range(j):
if lst[i+1] < lst[i]:
lst[i+1], lst[i] = lst[i], lst[i+1] if __name__ == "__main__":
lst = [randrange(10, 100) for i in range(10)] print(">>> before sort:", lst)
bubble_sort(lst)
print(">>> after sort: ", lst)

2. 选择排序 SelectionSort

2.1 算法描述

  1. 在未排序序列中找到最小元素,存放到排序序列的起始位置
  2. 从剩余未排序元素中继续寻找最小元素,放到已排序序列的末尾
  3. 以此类推,直到所有元素均排序完毕

2.2 选择排序的主要优点

  • 与数据移动有关
  • 如果某个元素位于正确的最终位置上,则它不会被移动
  • 选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上
  • 对 n 个元素进行排序总共进行至多 n-1 次交换
  • 所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种

2.3 性能分析

  • 最优时间复杂度:O(n2)
  • 最坏时间复杂度:O(n2)
  • 稳定性:不稳定(考虑升序每次选择最大的情况)

2.4 Python 代码实现

from random import randrange

def selection_sort(lst):
n = len(lst)
for i in range(n-1):
min_idx = i
for j in range(i+1, n):
if lst[j] < lst[min_idx]:
min_idx = j
if min_idx != i:
lst[i], lst[min_idx] = lst[min_idx], lst[i] if __name__ == "__main__":
lst = [randrange(10, 100) for i in range(10)] print(">>> before sort:", lst)
selection_sort(lst)
print(">>> after sort: ", lst)

3. 插入排序 Insertion sort

  • 是一种简单直观的排序算法

3.1 算法描述

  • 对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入

  • 在插入排序的实现上

    • 在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间

3.2 性能分析

  • 最优时间复杂度:O(n)(当序列已经处于升序状态时)
  • 最坏时间复杂度:O(n2)
  • 稳定性:稳定

3.3 Python 代码实现

from random import randrange

def insert_sort(lst):
for i in range(1, len(lst)):
for j in range(i, 0, -1):
if lst[j] < lst[j-1]:
lst[j], lst[j-1] = lst[j-1], lst[j] if __name__ == "__main__":
lst = [randrange(10, 100) for i in range(10)] print(">>> before sort:", lst)
insert_sort(lst)
print(">>> after sort: ", lst)

[DS+Algo] 005 三种简单排序及其代码实现的更多相关文章

  1. [DS+Algo] 006 两种简单排序及其代码实现

    目录 1. 快速排序 QuickSort 1.1 步骤 1.2 性能分析 1.3 Python 代码示例 2. 归并排序 MergeSort 2.1 步骤 2.2 性能分析 2.3 Python 代码 ...

  2. c语言实现基本的数据结构(二) 链表(包括链表的三种简单排序算法)

    #include "stdafx.h" #include <stdlib.h> //创建一个节点,data为value,指向NULL Node* Create(int ...

  3. 三种简单排序算法(java实现)

    一.冒泡排序 算法思想:遍历待排序的数组,每次遍历比较相邻的两个元素,如果他们的排列顺序错误就交换他们的位置,经过一趟排序后,最大的元素会浮置数组的末端.重复操                   作 ...

  4. JS三种简单排序算法

    冒泡排序:最简单.最慢.长度小于7的时候最优 插入排序:比冒泡要快比快速排序和希尔排序慢,数据量小的时候优势大 快速排序:速度很快  //js利用systemSort进行排序 systemSort: ...

  5. iOS开发UI篇—iOS开发中三种简单的动画设置

    iOS开发UI篇—iOS开发中三种简单的动画设置 [在ios开发中,动画是廉价的] 一.首尾式动画 代码示例: // beginAnimations表示此后的代码要“参与到”动画中 [UIView b ...

  6. 三种简单的html网页自动跳转方法

    三种简单的html网页自动跳转方法,可以让你在打开一个html网页时自动跳转到其它的页面. 方法/步骤   <html> <head> <title>正在跳转< ...

  7. 表单模糊查询的三种简单方式(springboot-h2-mybatis)

    前几天运营提到说后台管理系统有几个地方想要模糊查询..   想了下是简单的,就是要注意以前方法的被调用情况,进行增量改动,以免牵一发而动全身.整理一波记录下(本次案例是按名字模糊查询学生信息). 三种 ...

  8. <算法基础><排序>三种高级排序——快速排序,堆排序,归并排序

    这三种排序算法的性能比较如下: 排序名称 时间复杂度(平均) 时间复杂度(最坏) 辅助空间 稳定性 快速排序 O(nlogn) O(n*n) O(nlogn) 不稳定 堆排序 O(nlogn) O(n ...

  9. WPF之Binding的三种简单写法

    环境 类代码 public class Person:INotifyPropertyChanged { private string name; public string Name { get { ...

随机推荐

  1. Flask【第10篇】:自定义Form组件

    自定义Form组件 一.wtforms源码流程 1.实例化流程分析 1 # 源码流程 2 1. 执行type的 __call__ 方法,读取字段到静态字段 cls._unbound_fields 中: ...

  2. Hive 窗口函数LEAD LAG FIRST_VALUE LAST_VALUE

    窗口函数(window functions)对多行进行操作,并为查询中的每一行返回一个值. OVER()子句能将窗口函数与其他分析函数(analytical functions)和报告函数(repor ...

  3. kafka——分布式的消息队列系统

    总听公司人说kafka kafka... 所以这玩意到底是个啥? 好像是一个高级版的消息队列,什么高吞吐量,数据持久,消息均衡,emmm https://blog.csdn.net/nawenqian ...

  4. 21.栈的压入、弹出序列(python)

    题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压 ...

  5. 给DEDECMS广告管理中增加图片上传功能

    dedecms的广告管理功能稍微有点次,本文就是在dedecms广告管理原有的基础上增加广告图片上传功能. 安装方法,对应自己的dedecms版本下载对应的编码然后解压把里面的文件放在后台目录覆盖即可 ...

  6. Linux入门培训教程 linux网络编程socket介绍

    一.概念介绍 网络程序分为服务端程序和客户端程序.服务端即提供服务的一方,客户端为请求服务的一方.但实际情况是有些程序的客户端.服务器端角色不是这么明显,即互为Linux培训 客户端和服务端. 我们编 ...

  7. BZOJ 4769: 超级贞鱼 逆序对 + 归并排序

    手画几下序列的变换后发现逆序对数是恒定的,故只需对第 $0$ 年求逆序对即可. 树状数组会 $TLE$ 的很惨,需要用到归并排序来求逆序对. 其实就是省掉了一个离散化的时间,估计能比树状数组快一半的时 ...

  8. hdu_3466(01背包)

    其实,就是让C商品的q不等于p,其他都相同,这时,你就会发现如果要买C商品的话,肯定得先买C商品,因为买C商品的代价最大.所以,我们可以按照qi-pi的顺序来确定大顺序.这里我们还可以用更严谨的方式来 ...

  9. VMware NAT模式下,公司代理下上网 续

    这是在非公司环境下,VMware NAT 静态IP模式下上网 由于公司的限制,可能需要通过proxy上网. 下面是我在公司的配置(参考其他) 1. 修改 /etc/environment http_p ...

  10. bitmap相关工具类

    一,bitmap工具 封装了以下方法: 1,获取activity屏幕截图,保存为图片文件 2,从文件中获取截图,返回bitmap对象 package com.ctbri.weather.utils; ...