python实现归并排序算法
2018-11-22 20:02
531 查看
归并排序是典型的分治法的应用
思想:先递归分解数组,再合并数组
原理:将数组分解最小之后,然后合并两个有序数组,基本思想是比较两个数组的最前面的数,谁小就取谁,取完后,将相应的指针后移以为。然后再比较,直到一个数组为空,最后把另一个数组的剩余部分复制过来即可。
Python代码实现:
#归并排序 def merge_sort(alist): if len(alist) <= 1: return alist # 二分分解 num = len(alist) / 2 left = merge_sort(alist[:num]) right = merge_sort(alist[num:]) # 合并 return merge(left, right) def merge(left, right): '''合并操作,将两个有序数组left[]和right[]合并成一个大的有序数组''' # left与right的下标指针 l, r = 0, 0 result = [] while l < len(left) and r < len(right): if left[l] < right[r]: result.append(left[l]) l += 1 else: result.append(right[r]) r += 1 result += left[l:] result += right[r:] return result alist = [54, 26, 93, 17, 77, 31, 44, 55, 20] sorted_alist = merge_sort(alist) print(sorted_alist)
时间复杂度:
最优时间复杂度:O(nlongn)
最坏时间复杂度 :O(nlongn)
稳定性:稳定
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- python实现折半查找算法&&归并排序算法
- python实现归并排序算法
- 排序算法—归并排序算法分析与实现(Python)
- python 实现归并排序算法
- python 实现归并排序算法
- 归并排序算法-python实现
- 【Python】用python实现归并排序算法
- 排序算法集合(4)- Python实现的N路归并排序算法
- python实现折半查找和归并排序算法
- 理解python的staticmethod与classmethod实现
- 使用python的Flask实现一个RESTful API服务器端[翻译]
- python实现指定目录下批量文件的单词计数:并发版本
- python实现解析oui.txt并抽取MAC前缀及组织名称
- 调用python的sklearn实现Logistic Reression算法
- OpenCV图像识别:车牌定位算法源码,Python语言实现
- Python 列表实现字典的get功能
- Python实现线程池
- 图像灰度化的三种方法及matlab,c++,python实现
- python实现费波纳茨数列——递归、迭代
- 14行Python代码实现 n 皇后问题(可求出所有结果)