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 socket C/S结构的聊天室应用实现
Nov 30 Python
Djang中静态文件配置方法
Jul 30 Python
python实现上传下载文件功能
Nov 19 Python
python绘制条形图方法代码详解
Dec 19 Python
Python 实现淘宝秒杀的示例代码
Jan 02 Python
详解Django之auth模块(用户认证)
Apr 17 Python
解决Python找不到ssl模块问题 No module named _ssl的方法
Apr 29 Python
Python应用领域和就业形势分析总结
May 14 Python
Python中字符串List按照长度排序
Jul 01 Python
python logging模块书写日志以及日志分割详解
Jul 22 Python
python 怎样将dataframe中的字符串日期转化为日期的方法
Sep 26 Python
关于python3.9安装wordcloud出错的问题及解决办法
Nov 02 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提取字符串中的图片地址[正则表达式]
2011/11/12 PHP
php中print(),print_r(),echo()的区别详解
2014/12/01 PHP
php取得字符串首字母的方法
2015/03/25 PHP
PHP实现的通过参数生成MYSQL语句类完整实例
2016/04/11 PHP
PHP实现的注册,登录及查询用户资料功能API接口示例
2017/06/06 PHP
php array 转json及java 转换 json数据格式操作示例
2019/11/13 PHP
thinkphp5 + ajax 使用formdata提交数据(包括文件上传) 后台返回json完整实例
2020/03/02 PHP
js判断IE浏览器版本过低示例代码
2013/11/22 Javascript
JSON.parse()和JSON.stringify()使用介绍
2014/06/20 Javascript
如何让你的Lightbox支持滚轮缩放及Base64图片
2014/12/04 Javascript
后台获取ZTREE选中节点的方法
2015/02/12 Javascript
Bootstrap模态框水平垂直居中与增加拖拽功能
2016/11/09 Javascript
浅谈使用React.setState需要注意的三点
2017/12/18 Javascript
JS获取浏览器地址栏的多个参数值的任意值实例代码
2018/07/24 Javascript
微信小程序实现选项卡滑动切换
2020/10/22 Javascript
javascript实现固定侧边栏
2021/02/09 Javascript
python解析模块(ConfigParser)使用方法
2013/12/10 Python
在Django中限制已登录用户的访问的方法
2015/07/23 Python
python实现ID3决策树算法
2017/12/20 Python
Python cookbook(数据结构与算法)保存最后N个元素的方法
2018/02/13 Python
TensorFlow 实战之实现卷积神经网络的实例讲解
2018/02/26 Python
python3.8下载及安装步骤详解
2020/01/15 Python
Python Django form 组件动态从数据库取choices数据实例
2020/05/19 Python
美国家喻户晓的保健品品牌:Vitamin World(维他命世界)
2016/08/19 全球购物
Reebok俄罗斯官方网上商店:购买锐步运动服装和鞋子
2016/09/26 全球购物
计算机通信工程专业毕业生推荐信
2013/12/24 职场文书
教育科研先进个人材料
2014/01/26 职场文书
员工拓展培训方案
2014/02/15 职场文书
《高尔基和他的儿子》教学反思
2014/04/09 职场文书
《从现在开始》教学反思
2014/04/15 职场文书
2014预备党员批评与自我批评思想汇报
2014/09/20 职场文书
查摆问题整改措施范文
2014/10/11 职场文书
投资入股合作协议书
2014/10/28 职场文书
公司2015年终工作总结
2015/05/26 职场文书
2015年污水处理厂工作总结
2015/05/26 职场文书
Ruby使用Mysql2连接操作MySQL
2022/04/19 Ruby