位置: 编程技术 - 正文

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函数判断质数)

  • 车辆保险车船税怎么做会计分录
  • 减税后含税单价计算公式
  • 固定资产计入了主营业务成本,该怎么办
  • 小规模旅游业差额增值税税率
  • 无形资产有合同约定,怎么摊销?
  • 建筑企业增值税纳税义务发生时间如何确定
  • 应收账款的损失率怎么算
  • 会计利润包不包括营业外支出
  • 广告公司好进吗
  • 企业购入物资合同模板
  • 部分销售退回怎么开票
  • 公司注销固定资产清理需要开票吗
  • 农业生产企业是指什么
  • 小规模纳税人发票可以抵扣吗
  • 物业费纳税
  • 虚假享受税收优惠政策
  • 企业可以采用在产品按固定成本计算法的有
  • 法人向公司借款用途怎么写
  • 个体工商户核定征收怎么报税
  • 计提缴纳增值税怎么做账
  • 企业筹建期间可以自己发农民工工资么
  • 贴息债券计算公式
  • 初级会计实务的心得体会
  • 收到培训内容的英文
  • 新税法中工资薪金的规定
  • 认缴出资怎么记账
  • thinkphp怎么部署
  • 电脑打不了字只有拼音,按哪个键
  • 酒店的啤酒
  • 购入的无形资产
  • 收到发票已入账,退回怎么做账
  • 低值易耗品的三级科目有哪些
  • phpstudy备份数据库
  • php 时间格式转换
  • 发票系统技术维护费
  • 政府会计制度应付职工薪酬账务处理
  • vuejs props
  • vue的简介
  • 进项税额转出在申报的时候怎么填
  • 公司年夜饭怎么说话
  • 红字发票申请单怎么开
  • 速动资产扣除应纳税所得
  • dedecms安装步骤
  • 个体户增值税减免申报明细表怎么填
  • 常用sql脚本
  • mysql设置uuid
  • 职业年金是什么意思?退休后怎么算职业年金?
  • 发放职工薪酬计入什么科目
  • 固定资产折旧提头不提尾
  • 收到专利权投资的票据
  • 平均净资产怎么算公式的
  • 一般纳税人购货取得普通发票
  • 企业申请支付宝账号步骤
  • 天猫佣金是什么意思
  • mysql数据库迁移到达梦
  • 不一样的萧先生
  • centos7 tcp6
  • appservicesdkscripterror
  • gpedit.msc无法打开
  • 使用标准用户帐号的方法
  • 删除windows.old文件夹后 桌面没有了
  • 怎么设置虚拟硬盘储存路径
  • 磁盘限制
  • 笔记本运行WINCC不显示全屏
  • win7 64位旗舰版下载后怎样禁用搜索记录?win7禁用搜索记录的设置方法
  • kail Linux系统
  • FreeGLUT Tips: Resolve compile issue: error LNK1104: cannot open file 'freeglutd.lib'
  • com.android.phone无响应
  • 人工智能最受欢迎的一门编程语言
  • Shell脚本监控linux系统信息
  • asp.net runat
  • shell备份文件脚本
  • html超链接打开本地文件
  • 22号天蝎座的运势
  • js使用类
  • Android SimpleAdapter
  • 贵州电子税务局怎么登录
  • 小规模开票税金怎么算
  • 关税下降的好处
  • 工程增值税率从11%调整到9%
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设