八大排序算法的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异步回调机制实现和使用方法
Nov 26 Python
python threading模块操作多线程介绍
Apr 08 Python
使用FastCGI部署Python的Django应用的教程
Jul 22 Python
python编程开发之类型转换convert实例分析
Nov 13 Python
python中OrderedDict的使用方法详解
May 05 Python
Python requests发送post请求的一些疑点
May 20 Python
python 中文件输入输出及os模块对文件系统的操作方法
Aug 27 Python
使用python实现滑动验证码功能
Aug 05 Python
python模块常用用法实例详解
Oct 17 Python
Python简单实现词云图代码及步骤解析
Jun 04 Python
详解python安装matplotlib库三种失败情况
Jul 28 Python
去除python中的字符串空格的简单方法
Dec 22 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简单静态页生成过程
2008/03/27 PHP
destoon实现首页显示供应、企业、资讯条数的方法
2014/07/15 PHP
PHP积分兑换接口实例
2015/02/09 PHP
PHP的PDO错误与错误处理
2019/01/27 PHP
php+Ajax无刷新验证用户名操作实例详解
2019/03/04 PHP
js 获取中文拼音,Select自动匹配字母获取值的代码
2009/09/23 Javascript
使用jquery中height()方法获取各种高度大全
2014/04/02 Javascript
jQuery中on()方法用法实例详解
2015/02/06 Javascript
为什么JavaScript没有块级作用域
2016/05/22 Javascript
jQuery css() 方法动态修改CSS属性
2016/09/25 Javascript
利用jquery禁止外层滚动条的滚动
2017/01/05 Javascript
微信小程序 九宫格实例代码
2017/01/21 Javascript
给Easyui-Datebox设置隐藏或者不可用的解决方法
2017/05/26 Javascript
vue 实现移动端键盘搜索事件监听
2019/11/06 Javascript
JavaScript 浏览器对象模型BOM原理与常见用法实例分析
2019/12/16 Javascript
使用JS location实现搜索框历史记录功能
2019/12/23 Javascript
[14:03]2017DOTA2亚洲邀请赛开幕式:12神兵演绎水墨中华
2017/04/01 DOTA
Python算法应用实战之栈详解
2017/02/04 Python
Python聊天室程序(基础版)
2018/04/01 Python
Flask之flask-script模块使用
2018/07/26 Python
python将视频转换为全字符视频
2019/04/26 Python
如何更改 pandas dataframe 中两列的位置
2019/12/27 Python
Python爬虫实现模拟点击动态页面
2020/03/05 Python
python shell命令行中import多层目录下的模块操作
2020/03/09 Python
python 删除系统中的文件(按时间,大小,扩展名)
2020/11/19 Python
完美解决torch.cuda.is_available()一直返回False的玄学方法
2021/02/06 Python
The Hut美国/加拿大:英国领先的豪华在线百货商店
2019/03/26 全球购物
应届大学生自荐信
2013/12/05 职场文书
任命书模板
2014/06/04 职场文书
乡镇干部个人对照检查材料(群众路线)
2014/09/26 职场文书
2014年小学语文工作总结
2014/12/20 职场文书
2015年度保密工作总结
2015/04/24 职场文书
2016元旦主持人开场白
2015/12/03 职场文书
导游词之神仙居景区
2019/11/15 职场文书
SpringBoot整合Redis入门之缓存数据的方法
2021/11/17 Redis
CentOS下安装Jenkins的完整步骤
2022/04/07 Servers