位置: 编程技术 - 正文

python 排序算法总结及实例详解(python排序算法比较)

编辑:rootadmin

推荐整理分享python 排序算法总结及实例详解(python排序算法比较),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:Python排序算法,Python排序算法,Python排序算法,python排序算法有哪些,python排序算法比较,python排序算法有哪些,python排序算法有哪些,Python排序算法,内容如对您有帮助,希望把文章链接给更多的朋友!

总结了一下常见集中排序的算法

归并排序

归并排序也称合并排序,是分治法的典型应用。分治思想是将每个问题分解成个个小问题,将每个小问题解决,然后合并。

具体的归并排序就是,将一组无序数按n/2递归分解成只有一个元素的子项,一个元素就是已经排好序的了。然后将这些有序的子元素进行合并。

合并的过程就是 对 两个已经排好序的子序列,先选取两个子序列中最小的元素进行比较,选取两个元素中最小的那个子序列并将其从子序列中

去掉添加到最终的结果集中,直到两个子序列归并完成。

代码如下:

稳定,时间复杂度 O(nlog n)

插入排序

代码如下:

稳定,时间复杂度 O(n^2)

交换两个元素的值python中你可以这么写:a, b = b, a,其实这是因为赋值符号的左右两边都是元组

(这里需要强调的是,在python中,元组其实是由逗号“,”来界定的,而不是括号)。

选择排序

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到

排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所

有元素均排序完毕。

不稳定,时间复杂度 O(n^2)

希尔排序

希尔排序,也称递减增量排序算法,希尔排序是非稳定排序算法。该方法又称缩小增量排序,因DL.Shell于年提出而得名。

先取一个小于n的整数d1作为第一个增量,把文件的全部记录分成d1个组。所有距离为d1的倍数的记录放在同一个组中。先在各组内进行排序;

然后,取第二个增量d2

不稳定,时间复杂度 平均时间 O(nlogn) 最差时间O(n^s)1

堆排序 ( Heap Sort )

python 排序算法总结及实例详解(python排序算法比较)

“堆”的定义:在起始索引为 0 的“堆”中:

节点 i 的右子节点在位置 2 * i + ) 节点 i 的父节点在位置 floor( (i ? 1) / 2 ) : 注 floor 表示“取整”操作

堆的特性:

每个节点的键值一定总是大于(或小于)它的父节点

“最大堆”:

“堆”的根节点保存的是键值最大的节点。即“堆”中每个节点的键值都总是大于它的子节点。

上移,下移 :

当某节点的键值大于它的父节点时,这时我们就要进行“上移”操作,即我们把该节点移动到它的父节点的位置,而让它的父节点到它的位置上,然后我们继续判断该节点,直到该节点不再大于它的父节点为止才停止“上移”。

现在我们再来了解一下“下移”操作。当我们把某节点的键值改小了之后,我们就要对其进行“下移”操作。

方法:

我们首先建立一个最大堆(时间复杂度O(n)),然后每次我们只需要把根节点与最后一个位置的节点交换,然后把最后一个位置排除之外,然后把交换后根节点的堆进行调整(时间复杂度 O(lgn) ),即对根节点进行“下移”操作即可。 堆排序的总的时间复杂度为O(nlgn).

代码如下:

不稳定,时间复杂度 O(nlog n)

快速排序

快速排序算法和合并排序算法一样,也是基于分治模式。对子数组A[p…r]快速排序的分治过程的三个步骤为:

分解:把数组A[p…r]分为A[p…q-1]与A[q+1…r]两部分,其中A[p…q-1]中的每个元素都小于等于A[q]而A[q+1…r]中的每个元素都大于等于A[q];

解决:通过递归调用快速排序,对子数组A[p…q-1]和A[q+1…r]进行排序;

合并:因为两个子数组是就地排序的,所以不需要额外的操作。

对于划分partition 每一轮迭代的开始,x=A[r], 对于任何数组下标k,有:

1) 如果p≤k≤i,则A[k]≤x。

2) 如果i+1≤k≤j-1,则A[k]>x。

3) 如果k=r,则A[k]=x。

代码如下:

不稳定,时间复杂度 最理想 O(nlogn)最差时间O(n^2)

说下python中的序列:

列表、元组和字符串都是序列,但是序列是什么,它们为什么如此特别呢?序列的两个主要特点是索引操作符和切片操作符。索引操作符让我们可以从序列中抓取一个特定项目。切片操作符让我们能够获取序列的一个切片,即一部分序列,如:a = [‘aa','bb','cc'], print a[0] 为索引操作,print a[0:2]为切片操作。

希望通过此文掌握Python 算法排序的知识,谢谢大家对本站的支持!

python之Socket网络编程详解 什么是网络?网络是由节点和连线构成,表示诸多对象及其相互联系。在数学上,网络是一种图,一般认为专指加权图。网络除了数学定义外,还有具

Python ldap实现登录实例代码 下面一段代码是小编给大家介绍的Pythonldap实现登录实例代码,一起看看吧ldap_config={'ldap_path':'

Python脚本实现火车票查询系统 最近我看到看到使用python实现火车票查询,我自己也实现了,感觉收获蛮多的,下面我就把每一步骤都详细给分享出来。(注意使用的是python3)首先我

标签: python排序算法比较

本文链接地址:https://www.jiuchutong.com/biancheng/384497.html 转载请保留说明!

上一篇:一些常用的Python爬虫技巧汇总(一些常用的网络命令)

下一篇:python之Socket网络编程详解(python socketcan)

  • 增值税销项进项什么意思
  • 季度报表的利润表是填本月数填六月的书吗
  • 建筑公司收到劳务发票会计分录
  • 红字发票可以只开金额没有数量吗
  • 水果销售公司账务怎么做
  • 发票一年不能开超多少才不扣税费
  • 冲销以前年度营业外支出
  • 盈余公积转增股本的分录怎么写
  • 个税扣除是扣我们的钱吗
  • 哪些合同不需要缴纳印花税的通知
  • 筹办期的工资费用是什么
  • 债务转为股份的协议
  • 固定资产清理营业外支出汇算清缴需要调增吗
  • 无形资产摊销的年限规定
  • 交通违章罚款有优惠吗
  • 公司增值税发票有限额吗
  • 一般纳税人上个月没有申报这个月申报不了
  • 2017年金税盘服务费已全额减免,勾选系统怎么处理
  • 醋开票属于什么类
  • 房产税的常见四大检查点
  • 机票的抵扣率是多少
  • 业务宣传费企业所得税扣除标准是多少
  • 委托付款分录
  • 增值税税差调整原因
  • windows 10如何清除联网记录
  • 扣缴义务人申报和综合所得年度自行申报
  • 本月无生产,有折旧怎么办
  • 分公司打货款怎么做账
  • 2020年计提印花税怎么做账
  • 如何设置bios开关机
  • 电脑找不到ie浏览器
  • 默认网关不可用的解决办法
  • 工厂返费能拿到吗
  • 预付账款退款怎么做会计分录
  • 上一年度的费用入账需要分摊吗
  • 峡谷的人
  • 个人转让土地使用权可以开专票吗
  • 操作系统页表项怎么算
  • github ci/cd
  • 海关双抬头发票公司名可以更改吗
  • mongodb数据类型有哪些
  • windows mongodb安装与配置
  • 员工高铁票能抵扣吗
  • 国际货运代理可以分哪几类?
  • 盈余公积转增资本所有者权益会变吗
  • 红字发票冲销的申请表是税务局开吗
  • 库存现金是什么凭证
  • 物业公司劳务外包
  • 研发过程4个主要阶段
  • 其他综合收益为什么不影响利润
  • 长期合同价格怎么定
  • 哪些可以做进项税
  • 理财中的非保本是什么意思
  • 收付转三种凭证怎么装订
  • 补交增值税如何转管理费用
  • 职工福利费的好处
  • 工业企业固定资产投资
  • mysql 一键安装
  • Windows Server 2003将于7月14日停服 想用收费
  • 安装并激活navicat
  • 受益无穷还是受用无穷
  • mac10.15系统
  • mac文档怎么传给winds
  • win7系统每次开机都要选择用户
  • 鲁大师安装失败怎么回事
  • Linux中怎么安装nano已经有安装包了
  • win7系统电脑怎么连接wifi
  • JavaScript数组添加元素
  • fetch怎么用
  • node 内存泄漏
  • yarn和npm一起使用冲突
  • 用球体模拟天空的游戏
  • windows批处理命令教程
  • Python安装教程windous7
  • bootstrap需要学多久
  • 街道税务所职责和任务
  • 深圳车牌注销需要车辆到场吗
  • 企业税收怎么收
  • 淄博市地方税务局
  • 预缴增值税是否要预缴城建税及附加
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设