位置: 编程技术 - 正文

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

  • 个体户查账征收怎么交税?
  • 个税申报可以去税务局吗
  • 个人销售商品交什么税
  • 发票开错对方已抵扣怎么处理
  • 企业入库流程图
  • 个税代扣代缴返还手续费如何入账
  • 强制解除财务负责人
  • 个税手续费返还计入哪个科目
  • 增值税专用发票抵扣税额是什么意思
  • 费用会计具体工作总结
  • 股东向企业借款属于关联交易吗
  • 估算成本的会计要素
  • 公司存款利率
  • 商贸企业收到的检测费可以抵扣进项税吗
  • 补提企业所得税会计分录
  • 办理异地租房提取公积金流程
  • 跨年的费用需要冲减
  • 去年销售怎么算
  • 小规模不动产租赁税率是否减按1%
  • 预缴税款的附加税可以抵扣吗
  • 税收分类编码选错了会罚款么
  • 进项抵扣抵扣
  • 电器以旧换新的套路
  • 出租厂房算什么收入
  • 管理费用怎么记忆
  • 上月开的销项专票如何做废?
  • 筹备期间的开办企业是指
  • 购进半成品怎样做分录
  • 出口视同内销补缴增值税会计分录?
  • 电费预付之后又退回来了
  • 企业购入用于捐赠的物品
  • 报销怎么打
  • 鸿蒙怎么添加
  • 员工加班车费会计分录
  • 企业的往来账款包括哪些
  • 股东分红缴纳个税时间
  • 福利企业增值税优惠政策
  • vue 的watch
  • 财政返还土地奖金的规定
  • php设置图片将图片居中
  • 个人信息提供者
  • 销售提成属于什么费用
  • php实现和工作原理
  • Laravel5.1自定义500错误页面示例
  • 退回税款如何做账
  • 一般纳税人购进免税农产品如何抵扣进项税额
  • 社会团体不属于财政拨款的对象
  • PostgreSQL教程(七):函数和操作符详解(3)
  • 总结一周内学习的Sql经验(一)
  • 给子公司注资怎么做账
  • 工会经费可以列支哪些项目
  • 发放职工薪酬计入什么科目
  • 仓库盘点后的数据怎么处理
  • 营业外收入在汇算清缴里填哪张表
  • 单位之间借款还款怎么写
  • 行权期行权条件成就什么意思
  • 如何进行企业建账
  • VMWare linux mysql 5.7.13安装配置教程
  • windows自带截图保存在哪里
  • win7怎么调整
  • 删除命令windows
  • ubuntu笔记软件
  • centos基本环境
  • windowsxp设置语言
  • 怎么看win7
  • win10 提示你的设备遇到问题 需要重新启动
  • 输入法不跳出中文
  • jQuery基于ajax操作json数据简单示例
  • shell脚本语句
  • python程序讲解
  • js判断鼠标位置是否在元素区域内使用
  • JQuery Ajax WebService传递参数的简单实例
  • eclipse怎么查看项目的位置
  • 安卓中textview
  • 咪咕游戏包括什么
  • jquery的each循环
  • android 5.1 WIFI图标上的感叹号及其解决办法
  • 通用机油防伪查询
  • 税务窗口岗位职责
  • 南京税务局举报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设