网站首页 > 技术文章 正文
一、原理解析
归并排序不像前面讲过的几个排序那样直观,为了便于理解,我们先做个问题分解。
假设有两个已经排序好的数组:
let arrLeft = [1, 3, 4, 7] let arrRight = [2, 5, 6, 9]
如何把这两个已排序好的数组合并成一个排序好的数组呢?
可以新建一个空数组arrResult,比较arrLeft 第一位和 arrRight 第一位,哪个小就把这个数组的第一位拿出来push到空数组里。然后反复执行上面的逻辑,直到arrLeft或者arrRight其中一个变为空数组。最后再把另一个不为空的全部拿出来 push 到arrResult。 以下是代码:
function merge(leftArr, rightArr) { var resultArr = [] while(leftArr.length && rightArr.length) { resultArr.push(leftArr[0] <= rightArr[0] ? leftArr.shift() : rightArr.shift()) } return resultArr.concat(leftArr).concat(rightArr) }
那回头看看我们要真实解决的问题,如何对一个未排序的数组进行排序呢?
对于如下数组:
let arr = [4, 1, 2, 6, 9, 7, 3, 5]
我们可以把数组分成两部分:
let part1 = [4, 1, 2, 6] let part2 = [9, 7, 3, 5]
假设我们已经写好了我们最终要实现的排序方法 mergeSort。那么 mergeSort(arr) 等价于merge(mergeSort(part1), mergeSort(part2)) 。 即:对数组 arr 的排序,等价于把数组分两部分分别对每部分排序得到两个排序的数组,然后再利用刚刚写好的merge 方法把两个已经排序好的数组合并成一个最终排序好的数组。
那mergeSort(part1) 的结果又怎么计算呢?继续遵循上面的逻辑,对 part1继续分解,直到分解为对长度为1的数组进行排序(直接返回即可)。
function mergeSort() { //待补充 } mergeSort(arr) //等价于 merge(mergeSort(part1), mergeSort(part2))
总结:要排序一个大数组,可以把这个大数组拆分成两个小数组,把问题转变成分别排序这两个小数组,再把排序后的两个小数组通过简单的处理方式“归并为”最终需要的结果。 如何排序这两个小数组呢?循环刚刚的逻辑,直到数组拆分到极小(数组长度为1,排序的结果就是自己)。
二、代码实现
以下是 JavaScript 版本的的代码实现:
function mergeSort(arr) { var merge = function(leftArr, rightArr) { var resultArr = [] while(leftArr.length && rightArr.length) { resultArr.push(leftArr[0] <= rightArr[0] ? leftArr.shift() : rightArr.shift()) } return resultArr.concat(leftArr).concat(rightArr) } if(arr.length < 2) return arr let mid = arr.length >> 1 //取数组的中位下标,也可以用 parseInt(arr.length/2) return merge(mergeSort(arr.slice(0, mid)), mergeSort(arr.slice(mid))) }
三、复杂度
平均时间复杂度为 O(nlogn),性能极好。
本文作者:若愚。喜欢就点个赞,后续才有动力继续更新。如果或者发现文章中的错误,或者有更好的建议,欢迎算法交流群交流,加微信:xiedaimala02 拉入群
- 上一篇: 插入排序java java排序实现
- 下一篇: 17种编程语言实现排序算法-插入排序
猜你喜欢
- 2025-06-13 8个步骤,创建项目管理时间表(建立项目管理系统)
- 2025-06-13 配电柜里最全电气原件 安装 排序 电气元件名称 让你一目了然 电工必备
- 2025-06-13 html基础必备-列表标记,前端小白一看就会
- 2025-06-13 家族坟墓的多种排列形式,墓葬布局的排列布局(图解)
- 2024-10-03 17种编程语言实现排序算法-插入排序
- 2024-10-03 插入排序java java排序实现
- 2024-10-03 插入排序算法 插入排序算法c语言
- 2024-10-03 十大排序算法(javascript) 十大排序算法c语言
- 2024-10-03 常考算法题:无重复字符串的排列组合
- 2024-10-03 职场人士必备的“重要紧急排序法”,你一直用错了
你 发表评论:
欢迎- 518℃Oracle分析函数之Lag和Lead()使用
- 517℃几个Oracle空值处理函数 oracle处理null值的函数
- 511℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 502℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 497℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 488℃【数据统计分析】详解Oracle分组函数之CUBE
- 469℃Oracle有哪些常见的函数? oracle中常用的函数
- 467℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端定时器 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)