(四)前端javascript中的数据结构之归并排序

归并排序是一种分治算法, 其思想是:
将原始数组切分成较小的数组,直到每个小数组只有一
个位置,接着将小数组归并成较大的数组,直到最后只有一个排序完毕的大数组
归并排序是第一个可以被实际使用的排序算法。它比前面的几种排序方法效率要好很多

因为是分治思想,所以要用到递归。

代码实现

js 复制代码
//归并排序的特点
// 1.归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。
// 2.归并排序是一种稳定的排序方法。
// 3.归并排序是建立在归并操作上的一种有效的排序算法。归并操作(merge)指的是将两个有序的序列合并成一个有序序列的过程。
// 4.归并排序是一种时间复杂度为O(nlogn)的排序算法。
// 5.归并排序是一种稳定的排序方法。

function mergeSort(arr) {
  return mergeSortRecursion(arr);
}

function mergeSortRecursion(arr, type) {
  //如果数组长度小于等于1,直接返回
  if (arr.length <= 1) return arr;
  //计算中间值
  var mid = Math.floor(arr.length / 2);
  //拆分数组,为左右两部分,并递归
  var leftArr = arr.slice(0, mid);
  console.log("🚀 ~ mergeSortRecursion ~ leftArr:", leftArr);
  var rightArr = arr.slice(mid);
  console.log("🚀 ~ mergeSortRecursion ~ rightArr:", rightArr);
  console.log("🚀 ~ mergeSortRecursion ~ type:", type);
  console.log("aaa");

  return merge(
    mergeSortRecursion(leftArr, "left"),
    mergeSortRecursion(rightArr, "right")
  );
}

function merge(left, right) {
  console.log("🚀 ~ merge ~ right:", right);
  console.log("🚀 ~ merge ~ left:", left);
  let result = [],
    il = 0,
    ir = 0;
  while (il < left.length && ir < right.length) {
    if (left[il] < right[ir]) {
      result.push(left[il++]);
    } else {
      result.push(right[ir++]);
    }
  }
  while (il < left.length) {
    result.push(left[il++]);
  }
  while (ir < right.length) {
    result.push(right[ir++]);
  }
  console.log("🚀 ~ merge ~ result:", result);
  return result;
}

复杂度

  • 时间复杂度:O(nlogn)
  • 空间复杂度:O(n)
  • 稳定排序算法

测试

js 复制代码
    const demo = mergeSortRecursion([1, 5, 3, 4, 2,10,12])
    console.log("🚀 ~ demo:", demo)


一定要借助断点调试,查看执行的流程,不然实在无法理解这个实现过程,大佬就自便了

相关推荐
장숙혜几秒前
ElementUi的Dropdown下拉菜单的详细介绍及使用
前端·javascript·vue.js
火柴盒zhang3 分钟前
websheet之 编辑器
开发语言·前端·javascript·编辑器·spreadsheet·websheet
某公司摸鱼前端6 分钟前
uniapp 仿企微左边公司切换页
前端·uni-app·企业微信
WKK_9 分钟前
uniapp自定义封装tabbar
前端·javascript·小程序·uni-app
莫问alicia10 分钟前
react 常用钩子 hooks 总结
前端·javascript·react.js
阿让啊16 分钟前
C语言中操作字节的某一位
c语言·开发语言·数据结构·单片机·算法
Mintopia19 分钟前
图形学中的数学基础与 JavaScript 实践
前端·javascript·计算机图形学
Mintopia25 分钟前
Three.js 制作飘摇的草:从基础到进阶的全流程教学
前端·javascript·three.js
BillKu26 分钟前
Vue3父子组件数据双向同步实现方法
前端·javascript·vue.js
草莓啵啵~43 分钟前
搜索二叉树-key的搜索模型
数据结构·c++