冒泡排序

算法思想:

对于一组需要排序的数据,对于相邻的两个数进行比较,使较大(或者较小)的数一直向后推,经过多层排序之后,使整个序列是有序的。

算法实现:

def bubble_sort(L):
length = len(L)
if length == 0 or length == 1:
return L
for i in range(length):
for j in range(length-i-1):
if L[j] > L[j+1]:
temp = L[j]
L[j] = L[j+1]
L[j+1] = temp
return L print(bubble_sort(data))

算法的实现使用了两层for循环,其中对于外层for循环来说,第一次for循环,最大的数被推到最后面,第二次for循环,次大的数被推到次后面...依次类推,而内层for循环的作用就是实现将当前层次的最大数找出来,向后沉。

复杂度:

  • 时间复杂度

    平均情况O(n^2), 最好情况O(n), 最坏情况O(n^2)
  • 空间复杂度

    O(1)
  • 稳定性

    不稳定

快速排序

算法思想:

任意设置一个基准元素,一般是第一个或者最后一个,将序列以该基准元素为基准,分割成比他小的一部分和比他大的一部分,此时,该基准元素所在的位置就是排序终了之后的准确位置,在对左右两边的序列继续执行同样的操作,直整个个序列有序。

算法实现:

def quick_sort(lists, left, right):
if left >= right:
return lists
key = lists[left] # 用作基准
low = left
high = right
while left < right:
while left < right and lists[right] >= key:
right -= 1
lists[left] = lists[right]
while left < right and lists[left] <= key:
left += 1
lists[right] = lists[left] lists[right] = key
quick_sort(lists, low, left - 1)
quick_sort(lists, left + 1, high)
return lists print(quick_sort(data, 0, len(data)-1))

内层的while循环中,以key为基准,从序列的右边找出比key值小的元素,放在key的左边去,再从key的左边找出比key值大的元素,放在key的右边,此时正好填补了放到左边的的那个空位,多次循环,直到序列有序。

复杂度:

  • 时间复杂度

    平均情况O(nlog2n), 最好情况O(nlog2n), 最坏情况O(n^2)
  • 空间复杂度

    O(nlog2n)
  • 稳定性

    不稳定

选择排序

算法思想:

在需要排序的一组数中,选出最小(或者最大)的一个数与第一个位置的数交换,然后在剩下的数中在找到最小(或者最大)的数与第二个位置的数交换,一次类推,直到倒数第二个数与倒数第一个数交换完成为止。

算法实现:

def select_sort(L):
length = len(L)
if length == 0 or length == 1:
return L def _min(s):
'''
实现从后面的值中找到最小值的索引
'''
min = s
for i in range(s, length):
if L[i] < L[min]:
min = i
return min for i in range(length):
min = _min(i)
if i != min:
temp = L[min]
L[min] = L[i]
L[i] = temp
return L print(select_sort(data))

每一次循环,都将该次循环的i作为基准,从i后面的数中通过_min()函数来找到后面数据最小值的索引,在for循环的循环体内交换位置,目的是将小值放到前面去。这样,每一次循环,数中最前面的一部分数据是从小到大排序的,直到最后,所有的数据都是有序的为止。

复杂度:

  • 时间复杂度

    平均情况O(n^2), 最好情况O(n^2), 最坏情况O(n^2)
  • 空间复杂度

    O(1)
  • 稳定性

    不稳定

归并排序

算法思想:

主题思想是将两个有序表河滨更成为一个新的有序表,将待排序序列分位若干个子序列,每个子序列是有序的,然后在将其合并为一个整体,使用递归的思想。

算法实现:

def merge(left, right):
i, j = 0, 0
result = []
while i < len(left) and j < len(right):
if left[i] <= right[j]:
result.append(left[i])
i += 1
else:
result.append(right[j])
j += 1
result += left[i:]
result += right[j:]
return result def merge_sort(lists):
# 归并排序
if len(lists) <= 1:
return lists
num = int(len(lists) / 2)
left = merge_sort(lists[:num])
right = merge_sort(lists[num:])
return merge(left, right) print(merge_sort(data))

将一个序列一直对半拆分,分为若干个子序列,直到该子序列只有一个元素为止,然后将其合并。因此主要的问题就变成了如何将两个有序序列合并,这里新建一个空序列,遍历比较两个序列,将较小的元素放在新的序列中,直到某一个序列为空,此时很可能另外的一个序列非空,因此需要将剩余的已经有序的元素一次性添加到新建的序列中。

复杂度:

  • 时间复杂度

    平均情况O(nlog2n), 最好情况O(nlog2n), 最坏情况O(nlog2n)
  • 空间复杂度

    O(n)
  • 稳定性

    稳定

插入排序

算法思想:

将序列的第一个元素当做已经排序好的序列,然后从后面的第二个元素开始,逐个元素进行插入,直到整个序列有序为止。

算法实现:

def insert_sort(L):

    length = len(L)
if length==0 or length==1:
return L
for i in range(1,length):
value = L[i]
j = i-1
while j>=0 and L[j]>value:
L[j+1] = L[j]
j-=1
L[j+1] = value
return L print(insert_sort(data))

对于for循环来说,第一次循环结束,整个序列的第一个元素是有序的,第二次循环,前面两个元素是有序的,第三次for循环,前面三个元素是有序的...对于while循环来说,只要索引为i的前面某个元素比我们设置的“哨兵”value的值大,就把它放在后面去,直到前面所有的元素均比value小,这时候本次排序结束,本次排序的结果依然是有序的,因为上一次的结果是有序的,我们本次排序只是将一个新的值加入进去,并没有破坏之前的结构,因此将其称之为“插入排序”。

复杂度:

  • 时间复杂度

    平均情况O(n^2), 最好情况O(n), 最坏情况O(n^2)
  • 空间复杂度

    O(1)
  • 稳定性

    稳定

希尔排序

算法思想:

希尔排序是对直接插入排序的改进版本,又称为缩小增量排序,将整个序列分割成若干个子序列,分别进行直接插入排序,待各个子序列基本语序后,在对全体进行直接插入排序。

算法实现:

def shell_sort(lists):
count=len(lists)
step=2
group=int(count/step)
while group>0:
for i in range(group):
j=i+group
while j<count:
key=lists[j]
k=j-group
while k>=0:
if lists[k]>key:
lists[k+group]=lists[k]
lists[k]=key
k=k-group
j=j+group
group=int(group/step)
return lists
print(shell_sort(data))

常用排序算法的Python实现的更多相关文章

  1. 常用排序算法的python实现和性能分析

    常用排序算法的python实现和性能分析 一年一度的换工作高峰又到了,HR大概每天都塞几份简历过来,基本上一天安排两个面试的话,当天就只能加班干活了.趁着面试别人的机会,自己也把一些基础算法和一些面试 ...

  2. 【Python】常用排序算法的python实现和性能分析

    作者:waterxi 原文链接 背景 一年一度的换工作高峰又到了,HR大概每天都塞几份简历过来,基本上一天安排两个面试的话,当天就只能加班干活了.趁着面试别人的机会,自己也把一些基础算法和一些面试题整 ...

  3. 面试中常用排序算法的python实现和性能分析

    这篇是关于排序的,把常见的排序算法和面试中经常提到的一些问题整理了一下.这里面大概有3个需要提到的问题: 虽然专业是数学,但是自己还是比较讨厌繁琐的公式,所以基本上文章所有的逻辑,我都尽可能的用大白话 ...

  4. 几种常用排序算法的python实现

    1:快速排序 思想: 任意选取一个数据(通常选用数组的第一个数)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序. 一趟快速排序的算法是: 1)设置 ...

  5. Python实现常用排序算法

    Python实现常用排序算法 冒泡排序 思路: 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完 ...

  6. 第四百一十五节,python常用排序算法学习

    第四百一十五节,python常用排序算法学习 常用排序 名称 复杂度 说明 备注 冒泡排序Bubble Sort O(N*N) 将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮 ...

  7. 八大排序算法的 Python 实现

    转载: 八大排序算法的 Python 实现 本文用Python实现了插入排序.希尔排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序. 1.插入排序 描述 插入排序的基本操作就是将一个 ...

  8. Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法

    Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...

  9. 转载部长一篇大作:常用排序算法之JavaScript实现

    转载部长一篇大作:常用排序算法之JavaScript实现 注:本文是转载实验室同门王部长的大作,找实习找工作在即,本文颇有用处!原文出处:http://www.cnblogs.com/ywang172 ...

随机推荐

  1. 【leetcode 简单】第十一题 搜索插入位置

    给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会被按顺序插入的位置. 你可以假设数组中无重复元素. 示例 1: 输入: [1,3,5,6], 5 输 ...

  2. 微信小程序导航设置

    "tabBar": { "backgroundColor": "#ffffff", "color": "#00 ...

  3. NB二人组(二)----归并排序

    归并排序的思路: 归并算法程序(配合下图进行思考): def merge(li,low,mid,high): i = low j = mid + 1 ltmp=[] while i <= mid ...

  4. Javascript装饰器的妙用

    最近新开了一个Node项目,采用TypeScript来开发,在数据库及路由管理方面用了不少的装饰器,发觉这的确是一个好东西.装饰器是一个还处于草案中的特性,目前木有直接支持该语法的环境,但是可以通过 ...

  5. CRF++模板使用(转)

    CRF++模板构建分为两类,一类是Unigram标注,一类是Bigram标注. Unigram和Bigram模板分别生成CRF的状态特征函数  和转移特征函数  .其中  是标签,  是观测序列,   ...

  6. webgote的例子(6)SQL注入(盲注)

    SQL Injection - Blind (WS/SOAP) 本期演示的是盲注的手法.有些网站在与数据库交互的地方进行了很好的修饰,将报错的语句进行修改,即使你找到了注入点也无法下手拿数据,这个时候 ...

  7. Mysql自带profiling性能分析工具使用分享

    1. show variables like '%profiling%';(查看profiling信息)       2. set profiling=1;(开启profiling)   3. 执行S ...

  8. insta php-fpm 的配置

    [global]pid = /www/wdlinux/phps/70/var/run/php-fpm.piderror_log = /www/wdlinux/phps/70/var/log/php-f ...

  9. [ python ] 变量及基础的数据类型

    python2 和 python3 不同的编码方式 python2 默认编码方式是 ascii码 python3 默认编码方式是 utf-8 具体表现为:当 python3 和 python2 在打印 ...

  10. 数学中的Sin和Cos是什么意思?(转)

    数学中的Sin和Cos是什么意思? 作者:admin 分类:生活随笔 发表于 2012年03月21日 16:48 问:数学中的Sin和Cos是什么意思? 答:sin, cos, tan 都是三角函数, ...