位置: 编程技术 - 正文

Python编程中归并排序算法的实现步骤详解(归并代码)

编辑:rootadmin

推荐整理分享Python编程中归并排序算法的实现步骤详解(归并代码),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python数据合并的主要函数有哪些?,归并算法python,python合并数据集,python 归并排序详解,归并算法python,python数据合并的主要函数有哪些?,python中的并,python 归并排序详解,内容如对您有帮助,希望把文章链接给更多的朋友!

基本思想:归并排序是一种典型的分治思想,把一个无序列表一分为二,对每个子序列再一分为二,继续下去,直到无法再进行划分为止。然后,就开始合并的过程,对每个子序列和另外一个子序列的元素进行比较,依次把小元素放入结果序列中进行合并,最终完成归并排序。归并操作过程:

申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列设定两个指针,最初位置分别为两个已经排序序列的起始位置比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置重复步骤3直到某一指针达到序列尾将另一序列剩下的所有元素直接复制到合并序列尾上述说法是理论表述,下面用一个实际例子说明:

例如一个无序数组

首先将这个数组通过递归方式进行分解,直到:

然后开始合并排序,也是用递归的方式进行:

两个两个合并排序,得到:

上一步中,其实也是按照本步骤的方式合并的,只不过由于每个list中一个数,不能完全显示过程。下面则可以完全显示过程。

初始:

Python编程中归并排序算法的实现步骤详解(归并代码)

第1步,顺序从a,b中取出一个数字:2,1 比较大小后放入c中,并将该数字从原list中删除,结果是:

第2步,继续从a,b中按照顺序取出数字,也就是重复上面步骤,这次是:2,3 比较大小后放入c中,并将该数字从原list中删除,结果是:

第3步,再重复前边的步骤,结果是:

最后一步,将6追加到c中,结果形成了:

通过反复应用上面的流程,实现[1,2,3,6]与[7]的合并

最终得到排序结果

本文列举了三种python的实现方法:

方法1:将前面讲述的过程翻译过来了,略先拙笨

方法2:在按照顺序取数值方面,应用了list.pop()方法,代码更紧凑简洁

方法3:原来在python的模块heapq中就提供了归并排序的方法,只要将分解后的结果导入该方法即可。

使用Python判断质数(素数)的简单方法讲解 质数又称素数。指在一个大于1的自然数中,除了1和此整数自身外,不能被其他自然数整除的数。素数在数论中有着很重要的地位。比1大但不是素数的

Python环境下搭建属于自己的pip源的教程 一、安装pip2pi工具:pipinstallpip2pi或:

Python使用Paramiko模块编写脚本进行远程服务器操作 简介:paramiko是python(2.2或更高)的模块,遵循SSH2协议实现了安全(加密和认证)连接远程机器。安装所需软件包:

标签: 归并代码

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

上一篇:Python手机号码归属地查询代码(python 电话号码)

下一篇:使用Python判断质数(素数)的简单方法讲解(python函数判断质数)

  • 工业企业应缴纳的税金有哪些
  • 银行电子承兑到期多久时间之内可以兑现
  • 资产负债表其他应付款包括哪些
  • 员工补偿金是按上十二个月的平均工资
  • 车辆审验费的会计分录
  • 所得税费用的确认方法
  • 企业奖励的目的
  • 债券置换债务
  • 进口货物需要交哪些税
  • 不够起征点免缴的增值税如何做税务处理?
  • 按最低标准买社保30年退休后每个月领多少钱
  • 股票转让所得不交增值税
  • 工会经费应该计入人工成本吗
  • 职工食堂的费用怎么入账
  • 股息率超过10%的公司
  • 从财务报表中可以了解企业的哪些信息?作用是什么?
  • 企业赠送客户产品如何账务处理
  • 申报印花税填表过程
  • 1697510840
  • 公司钱被取走怎么处理
  • 不动产租金收入缴纳增值税
  • mac电脑新手使用
  • win7提示windows进行了未授权的更改
  • windows7部分的更新安装失败怎么办?
  • 键盘灯无法开启
  • 房屋装修补偿款 避税
  • 不合规发票扣除多少
  • 质量赔偿款要交税吗
  • 带息应收票据会计处理,到期
  • 夸克到底有什么用
  • 将时间序列转化为图像
  • 汇算清缴应补税额为负数
  • phpxdebug
  • yolov5改进点
  • smb命令执行
  • ctrl ate del
  • 企业所得税资产总额根据什么填
  • mysql5.6解压版安装教程
  • phpcms二次开发教程
  • 一般纳税人不抵扣怎样交税
  • 母子公司之间借款要交税吗
  • 数据库参数错误
  • 当月业务的发票可以次月开吗
  • 劳务总价包干
  • 企业为职工租房合法吗
  • 工程结算收入是否缴纳增值税
  • 税控盘服务费小规模可以抵扣吗
  • 什么税能计入税额
  • 公户的利息收入账务处理咋处理
  • 转账支票需要知道开户行吗
  • 季度盈利弥补以前年度亏损的账务处理
  • 企业里面不征税的有哪些
  • 公司销售部门购买产品
  • mysql新手视频教学
  • win7安装mysql8.0.17
  • sql server自动生成id
  • windows电源图标消失
  • linux系统讲解
  • linux批量操作
  • win 注册表
  • config是什么文件夹
  • win7桌面右下角输入法图标不见了
  • xp启动项设置在哪里设置
  • win7系统电脑图标不见了
  • win8如何进行系统还原
  • linux扩容inode
  • 如何在linux系统中创建空文件
  • bootstrap designer
  • 如何使用jquery插件
  • 网络自定义怎么打开
  • for语句的执行过程图解
  • node搭建博客
  • python的idle打不开解决办法
  • android view类
  • c# addin
  • 电子税务局申报表在哪里查询
  • 企业清算所得税申报表填写范本
  • 深圳个税官网
  • 药店迁址流程2019
  • 济南车辆购置税完税证明电子版
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设