golang/python实现归并排序实例代码


Posted in Python onAugust 30, 2020

归并排序

思路:将数组不断二分,然后合并为有序数组

C++实现:

void mergeSort(T arr[], int left,int right) { //对arr[left,right]的范围进行排序
 if (left >= right)
  return;
 int mid = (left + right) / 2;
 mergeSort(arr, left, mid);
 mergeSort(arr, mid + 1, right); 
 merge(arr, left, mid, right); //合并两部分
}

template<typename T>
void __merge(T arr[], int left, int mid, int right) { //将arr[left,mid] 和 arr[mid+1,right] 两部分进行归并

 T *tmp=new T[right-left+1];
 for (int i = left; i <= right; i++)
  tmp[i - left] = arr[i]; //先把arr(需要合并的左右片段) 复制给tmp

 int i = left, j = mid + 1; // i 做为左半部分的指针 j作为右半部分的指针
 for (int k = left; k <= right; k++) {
  if (i > mid) { // 左半部分 已经合入完了,将右半部分剩下的 全部合入
   arr[k] = tmp[j - left];
   j++;
  }
  else if (j > right) { // 右半部分 已经合入完了,将左半部分剩下的 全部合入
   arr[k] = tmp[i - left];
   i++;
  }
  else if (tmp[i - left] < tmp[j - left]) {
   arr[k] = tmp[i - left];
   i++;
  }
  else {
   arr[k] = tmp[j - left];
   j++;
  }
 }
 delete[] tmp;
}

GoLang实现:

func mergeSort(arr []int, left, right int) {
 if left >= right {
  return
 }
 mid := left + (right-left)/2
 mergeSort(arr, left, mid) // 递归调用,分别对左右部分进行归并排序
 mergeSort(arr, mid+1, right)
 merge(arr, left, mid, right) // 将左右部分进行合并
}

func merge(arr []int, left, mid, right int) {
 // 将要合并的部分做个拷贝
 var tmp []int = make([]int, right-left+1)
 for i, j := left, 0; i <= right; i++ {
  tmp[j] = arr[i]
  j++
 }
 // i做为左半部分的指针 j作为右半部分的指针
 var i, j int = left, mid+1
 for k := left; k <= right; k++ {
  if i > mid { // 左半部分 已经合入完了,将右半部分剩下的 全部合入
   arr[k] = tmp[j-left]
   j++
  } else if j > right { // 右半部分 已经合入完了,将左半部分剩下的 全部合入
   arr[k] = tmp[i-left]
   i++
  } else if tmp[i-left] > tmp[j-left] {
   arr[k] = tmp[j-left]
   j++
  } else {
   arr[k] = tmp[i-left]
   i++
  }
 }
}

python实现:

python 的实现方法和上面不一样,上面两种方法都是在原始数组上直接进行修改的

def mergeSort(arr):
 if len(arr) <= 1:
  return arr
 mid = len(arr) // 2
 left = mergeSort(arr[:mid]) # 分别对左右部分排序
 right = mergeSort(arr[mid:])
 return merge(left, right) # 合并左右部分为有序数组


def merge(left, right):
 result = []
 num_left, num_right = left.pop(0), right.pop(0) # 分别取出左右部分的第0个元素
 while True:
  if num_left < num_right:
   result.append(num_left)
   try:
    num_left = left.pop(0)
   except IndexError:
    result.append(num_right)
    result.extend(right)
    break
  else:
   result.append(num_right)
   try:
    num_right = right.pop(0)
   except IndexError:
    result.append(num_left)
    result.extend(left)
    break
 return result


if __name__ == '__main__':
 from random import shuffle

 arr = list(range(30))
 shuffle(arr)
 arr = mergeSort(arr)
 print(arr)

总结

到此这篇关于golang/python实现归并排序的文章就介绍到这了,更多相关golang python归并排序内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python实现zencart产品数据导入到magento(python导入数据)
Apr 03 Python
理解python多线程(python多线程简明教程)
Jun 09 Python
python网络编程学习笔记(八):XML生成与解析(DOM、ElementTree)
Jun 09 Python
在Python程序中操作MySQL的基本方法
Jul 29 Python
python 定时任务去检测服务器端口是否通的实例
Jan 26 Python
Python获取当前脚本文件夹(Script)的绝对路径方法代码
Aug 27 Python
浅析使用Python搭建http服务器
Oct 27 Python
基于Python执行dos命令并获取输出的结果
Dec 30 Python
Numpy 理解ndarray对象的示例代码
Apr 03 Python
解析python 中/ 和 % 和 //(地板除)
Jun 28 Python
Python使用requests模块爬取百度翻译
Aug 25 Python
Pytorch可视化的几种实现方法
Jun 10 Python
python创建文本文件的简单方法
Aug 30 #Python
python 中的9个实用技巧,助你提高开发效率
Aug 30 #Python
Python Map 函数的使用
Aug 28 #Python
python实现单机五子棋
Aug 28 #Python
Python3+selenium配置常见报错解决方案
Aug 28 #Python
Python 中如何写注释
Aug 28 #Python
Python操作Word批量生成合同的实现示例
Aug 28 #Python
You might like
小偷PHP+Html+缓存
2006/11/25 PHP
PHP多个版本的分析解释
2011/07/21 PHP
php实现两个数组相加的方法
2015/02/17 PHP
PHP实现蛇形矩阵,回环矩阵及数字螺旋矩阵的方法分析
2017/05/29 PHP
javascript学习笔记(十三) js闭包介绍(转)
2012/06/20 Javascript
javascript学习笔记(十六) 系统对话框(alert、confirm、prompt)
2012/06/20 Javascript
js单词形式的运算符
2014/05/06 Javascript
node.js中的fs.chownSync方法使用说明
2014/12/16 Javascript
javascript jquery对form元素的常见操作详解
2016/06/12 Javascript
JS正则表达式学习之贪婪和非贪婪模式实例总结
2016/12/26 Javascript
Vue.js系列之项目搭建(1)
2017/01/03 Javascript
微信小程序封装http访问网络库实例代码
2017/05/24 Javascript
利用nodeJs anywhere搭建本地服务器环境的方法
2018/05/12 NodeJs
async/await优雅的错误处理方法总结
2019/01/30 Javascript
node.js中ws模块创建服务端和客户端,网页WebSocket客户端
2019/03/06 Javascript
Vue防止白屏添加首屏动画的实例
2019/10/31 Javascript
基于Vue+ElementUI的省市区地址选择通用组件
2019/11/20 Javascript
nodejs如何在package.json中设置多条启动命令
2020/03/16 NodeJs
vue 子组件watch监听不到prop的解决
2020/08/09 Javascript
[43:32]Winstrike vs VGJ.S 2018国际邀请赛淘汰赛BO3 第一场 8.23
2018/08/24 DOTA
[01:00:13]完美世界DOTA2联赛 LBZS vs Forest 第一场 11.07
2020/11/09 DOTA
分析用Python脚本关闭文件操作的机制
2015/06/28 Python
利用Python破解验证码实例详解
2016/12/08 Python
python中单例常用的几种实现方法总结
2018/10/13 Python
在Python中定义一个常量的方法
2018/11/10 Python
django模板结构优化的方法
2019/02/28 Python
python实现可变变量名方法详解
2019/07/01 Python
Python 实现自动导入缺失的库
2019/10/29 Python
WEB控件及HTML服务端控件能否调用客户端方法?如果能,请解释如何调用?
2015/08/25 面试题
最新党员的自我评价分享
2013/11/04 职场文书
银行纠风工作实施方案
2014/06/08 职场文书
交通事故协议书范本
2014/11/18 职场文书
欠款证明
2015/06/24 职场文书
送给小学生的暑假礼物!小学生必背99首古诗
2019/07/02 职场文书
详解JSON.parse和JSON.stringify用法
2022/02/18 Javascript
HttpClient实现文件上传功能
2022/08/14 Java/Android