位置: 编程技术 - 正文

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

  • 挂车和牵引车如何选
  • 经营性现金净流量为负数怎么解释
  • 利息资本化计入什么现金流量科目
  • 所得税汇算清缴后发现有误怎么办
  • 出资人和法人承担责任
  • 所得税年报工资薪金支出怎么填
  • 简易征收增值税怎么做账
  • 分配本月工资及福利费会计分录
  • 土地租赁合同要公证吗
  • 证券交易所风险公告怎么写
  • 财务费用汇兑损益是什么意思
  • 用党费返还款购置资产应如何账务处理?
  • 收到车辆保险返还会计分录
  • 退回以前年度费用怎么做帐
  • 个人开增值税普通发票税率
  • 分票报关合票出提单怎么清关
  • 二房东税务局开发票
  • 轨道交通很高兴 土地税优惠来了
  • 股权转让的公允价值
  • 所得税汇算成本调减会计分录
  • 提现属于支出吗
  • 转让费入什么会计分录
  • windowsserver2003设置用户密码
  • thinkphp 路由
  • 采购涉及哪些部门
  • 总包和分包是什么关系
  • 商品盘点短缺和溢余的核算
  • oauth认证流程
  • vue实现鼠标悬浮 显示全部内容
  • 纳税人超过应缴纳税额缴纳的税款
  • 关联方核对
  • 光下的村庄环境描写
  • js如何实现异步编程
  • php静态方法可以被继承吗
  • 实现php搜索框代码
  • 企业所得税纳税人包括哪些类型
  • 豪华车消费税的计算公式
  • 个税累积税阶
  • 小规模开劳务费可以开多少
  • 织梦自定义字段
  • mongodb4.0安装教程
  • 海关进口增值税专用缴款书如何抵扣
  • 模具费收入计入什么科目
  • 固定资产的主要风险和关键控制点有哪些?
  • PostgreSQL 角色与用户管理介绍
  • 公司与个人可以合伙吗
  • 资本化支出计入什么科目
  • 建筑行业怎么确认主营业务收入
  • 对公账户原路退回备注怎么写
  • 应交增值税为什么在借方
  • 国有控股企业股权转让程序
  • 出口样品的销售好做吗
  • 固定资产为什么不能直接计入费用
  • 企业购入树木花草如何入账
  • 办公费用包含哪里费用
  • centos6.2安装
  • sqlserver 自动备份所有数据库的SQL
  • win7如何设置自动锁屏时间
  • win7无法识别usb设备如何解决
  • 微软为什么放弃win10
  • win8系统摄像头怎么打开
  • wind启动项
  • win8手机版
  • windows8.1的设置在哪
  • win10一年更新一次
  • xp电脑网络连接配置异常怎么办
  • win7系统怎么把c盘的内存加到d盘
  • 桌面的word
  • win7还原电脑系统的步骤
  • opengl基础知识
  • 什么是四个菜
  • javascript操作文件
  • uk开票软件如何赋码
  • 成品油和非成品油的税务知识
  • 国家税务总局网站登录入口官网
  • 停车定额费发票还能用吗
  • 税务年报截止日期2022
  • 2020年安徽省护理技能大赛视频播放
  • 河北电子税务局社保缴费流程
  • 车辆报废补贴怎么拿
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设