(四)前端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)


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

相关推荐
SharkWeek.1 小时前
【力扣Hot 100】普通数组2
数据结构·算法·leetcode
会说法语的猪1 小时前
uniapp使用uni.navigateBack返回页面时携带参数到上个页面
前端·uni-app
Amd7946 小时前
深入探讨索引的创建与删除:提升数据库查询效率的关键技术
数据结构·sql·数据库管理·索引·性能提升·查询优化·数据检索
古蓬莱掌管玉米的神9 小时前
vue3语法watch与watchEffect
前端·javascript
林涧泣9 小时前
【Uniapp-Vue3】uni-icons的安装和使用
前端·vue.js·uni-app
雾恋9 小时前
AI导航工具我开源了利用node爬取了几百条数据
前端·开源·github
拉一次撑死狗9 小时前
Vue基础(2)
前端·javascript·vue.js
祯民10 小时前
两年工作之余,我在清华大学出版社出版了一本 AI 应用书籍
前端·aigc
热情仔10 小时前
mock可视化&生成前端代码
前端
m0_7482463510 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端