八大排序算法的Python实现


Posted in Python onJanuary 28, 2021

Python实现八大排序算法,具体内容如下

1、插入排序

描述

插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。

代码实现

def insert_sort(lists):
 # 插入排序
 count = len(lists)
 for i in range(1, count):
  key = lists[i]
  j = i - 1
  while j >= 0:
   if lists[j] > key:
    lists[j + 1] = lists[j]
    lists[j] = key
   j -= 1
 return lists

2、希尔排序

描述

希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。

代码实现

def shell_sort(lists):
 # 希尔排序
 count = len(lists)
 step = 2
 group = count / step
 while group > 0:
  for i in range(0, group):
   j = i + group
   while j < count:
    k = j - group
    key = lists[j]
    while k >= 0:
     if lists[k] > key:
      lists[k + group] = lists[k]
      lists[k] = key
     k -= group
    j += group
  group /= step
 return lists

3、冒泡排序

描述

它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

代码实现

def bubble_sort(lists):
 # 冒泡排序
 count = len(lists)
 for i in range(0, count):
  for j in range(i + 1, count):
   if lists[i] > lists[j]:
    lists[i], lists[j] = lists[j], lists[i]
 return lists

4、快速排序

描述

通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

代码实现

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

5、直接选择排序

描述

基本思想:第1趟,在待排序记录r1 ~ r[n]中选出最小的记录,将它与r1交换;第2趟,在待排序记录r2 ~ r[n]中选出最小的记录,将它与r2交换;以此类推,第i趟在待排序记录r[i] ~ r[n]中选出最小的记录,将它与r[i]交换,使有序序列不断增长直到全部排序完毕。

代码实现

def select_sort(lists):
 # 选择排序
 count = len(lists)
 for i in range(0, count):
  min = i
  for j in range(i + 1, count):
   if lists[min] > lists[j]:
    min = j
  lists[min], lists[i] = lists[i], lists[min]
 return lists

6、堆排序

描述

堆排序(Heapsort)是指利用堆积树(堆)这种数据结构所设计的一种排序算法,它是选择排序的一种。可以利用数组的特点快速定位指定索引的元素。堆分为大根堆和小根堆,是完全二叉树。大根堆的要求是每个节点的值都不大于其父节点的值,即A[PARENT[i]] >= A[i]。在数组的非降序排序中,需要使用的就是大根堆,因为根据大根堆的要求可知,最大的值一定在堆顶。

代码实现

# 调整堆
def adjust_heap(lists, i, size):
 lchild = 2 * i + 1
 rchild = 2 * i + 2
 max = i
 if i < size / 2:
  if lchild < size and lists[lchild] > lists[max]:
   max = lchild
  if rchild < size and lists[rchild] > lists[max]:
   max = rchild
  if max != i:
   lists[max], lists[i] = lists[i], lists[max]
   adjust_heap(lists, max, size)

# 创建堆
def build_heap(lists, size):
 for i in range(0, (size/2))[::-1]:
  adjust_heap(lists, i, size)

# 堆排序
def heap_sort(lists):
 size = len(lists)
 build_heap(lists, size)
 for i in range(0, size)[::-1]:
  lists[0], lists[i] = lists[i], lists[0]
  adjust_heap(lists, 0, i)

7、归并排序

描述

归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。

归并过程为:比较a[i]和a[j]的大小,若a[i]≤a[j],则将第一个有序表中的元素a[i]复制到r[k]中,并令i和k分别加上1;否则将第二个有序表中的元素a[j]复制到r[k]中,并令j和k分别加上1,如此循环下去,直到其中一个有序表取完,然后再将另一个有序表中剩余的元素复制到r中从下标k到下标t的单元。归并排序的算法我们通常用递归实现,先把待排序区间[s,t]以中点二分,接着把左边子区间排序,再把右边子区间排序,最后把左区间和右区间用一次归并操作合并成有序的区间[s,t]。

代码实现

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 = len(lists) / 2
 left = merge_sort(lists[:num])
 right = merge_sort(lists[num:])
 return merge(left, right)

8、基数排序

描述

基数排序(radix sort)属于“分配式排序”(distribution sort),又称“桶子法”(bucket sort)或bin sort,顾名思义,它是透过键值的部份资讯,将要排序的元素分配至某些“桶”中,藉以达到排序的作用,基数排序法是属于稳定性的排序,其时间复杂度为O (nlog(r)m),其中r为所采取的基数,而m为堆数,在某些时候,基数排序法的效率高于其它的稳定性排序法。

代码实现

import math
def radix_sort(lists, radix=10):
 k = int(math.ceil(math.log(max(lists), radix)))
 bucket = [[] for i in range(radix)]
 for i in range(1, k+1):
  for j in lists:
   bucket[j/(radix**(i-1)) % (radix**i)].append(j)
  del lists[:]
  for z in bucket:
   lists += z
   del z[:]
 return lists

以上就是Python实现八大排序算法的详细介绍,希望对大家的学习有所帮助。

Python 相关文章推荐
python以环状形式组合排列图片并输出的方法
Mar 17 Python
python 中的int()函数怎么用
Oct 17 Python
对python的文件内注释 help注释方法
May 23 Python
python 实现生成均匀分布的点
Dec 05 Python
Python将列表中的元素转化为数字并排序的示例
Dec 25 Python
python模拟点击网页按钮实现方法
Feb 25 Python
Keras自定义IOU方式
Jun 10 Python
python如何输出反斜杠
Jun 18 Python
Python 字符串池化的前提
Jul 03 Python
Pytest如何使用skip跳过执行测试
Aug 13 Python
JupyterNotebook 输出窗口的显示效果调整实现
Sep 22 Python
python装饰器代码解析
Mar 23 Python
详解C++编程中一元运算符的重载
Jan 19 #Python
Python中使用Queue和Condition进行线程同步的方法
Jan 19 #Python
简单总结Python中序列与字典的相同和不同之处
Jan 19 #Python
举例讲解如何在Python编程中进行迭代和遍历
Jan 19 #Python
Python的自动化部署模块Fabric的安装及使用指南
Jan 19 #Python
Python编程中time模块的一些关键用法解析
Jan 19 #Python
Python编程中的文件读写及相关的文件对象方法讲解
Jan 19 #Python
You might like
PHP利用Socket获取网站的SSL证书与公钥
2017/06/18 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
PHP实现转盘抽奖算法分享
2020/04/15 PHP
javaScript checkbox 全选/反选及批量删除
2010/04/28 Javascript
jQuery lazyload 的重复加载错误以及修复方法
2010/11/19 Javascript
mailto的使用技巧分享
2012/12/21 Javascript
JS实现重新加载当前页面
2016/11/29 Javascript
原生JS实现简单放大镜效果
2017/02/08 Javascript
详谈jQuery unbind 删除绑定事件 / 移除标签方法
2017/03/02 Javascript
详解js静态资源文件请求的处理
2017/08/01 Javascript
vue实现一拉到底的滑动验证
2019/07/25 Javascript
JavaScript进制转换实现方法解析
2020/01/18 Javascript
使用js实现单链解决前端队列问题的方法
2020/02/03 Javascript
利用python程序帮大家清理windows垃圾
2017/01/15 Python
Flask框架Jinjia模板常用语法总结
2018/07/19 Python
python 使用正则表达式按照多个空格分割字符的实例
2018/12/20 Python
对python捕获ctrl+c手工中断程序的两种方法详解
2018/12/26 Python
Python线程之定位与销毁的实现
2019/02/17 Python
浅谈Python的方法解析顺序(MRO)
2020/03/05 Python
如何基于python3和Vue实现AES数据加密
2020/03/27 Python
html5的localstorage详解
2017/05/09 HTML / CSS
DERMAdoctor官网:美国著名皮肤护理品牌
2019/07/06 全球购物
全球领先的中国制造商品在线批发平台:DHgate
2020/01/28 全球购物
Stührling手表官方网站:男女高品质时尚手表的领先零售商
2021/01/07 全球购物
毕业生求职的求职信
2013/12/05 职场文书
国贸类专业毕业生的求职信分享
2013/12/08 职场文书
数控机床专业自荐信
2014/05/19 职场文书
机关党员进社区活动总结
2014/07/05 职场文书
房地产端午节活动方案
2014/08/24 职场文书
2014年十一国庆节爱国演讲稿
2014/09/23 职场文书
老员工辞职信范文
2015/05/12 职场文书
百家讲坛观后感
2015/06/12 职场文书
2015年小学语文教师工作总结
2015/10/23 职场文书
加薪申请书应该这样写!
2019/07/04 职场文书
5行Python代码实现一键批量扣图
2021/06/29 Python
nginx访问报403错误的几种情况详解
2022/07/23 Servers