数据结构和算法之归并排序

2023-09-18 09:41:39

归并排序Merge Sort是一种基于分治思想的排序算法,通过将待排序的数组分成两个子数组,分别对两个子数组进行排序,最后将排序好的子数组合并成一个有序数组。它的基本思想是将两个有序的子序列合并成一个有序的序列。

代码如下:

// 归并排序算法
function mergeSort(arr) {
  // 递归出口,当数组长度小于等于1时,直接返回数组本身
  if (arr.length <= 1) {
    return arr;
  }

  // 找到数组的中间位置,将数组分成两个子数组
  const mid = Math.floor(arr.length / 2);
  const left = arr.slice(0, mid);
  const right = arr.slice(mid);

  // 递归对左右两个子数组进行排序
  const sortedLeft = mergeSort(left);
  const sortedRight = mergeSort(right);

  // 合并两个有序的子数组
  return merge(sortedLeft, sortedRight);
}

// 合并两个有序的子数组
function merge(left, right) {
  const merged = [];
  let i = 0; // 左子数组指针
  let j = 0; // 右子数组指针

  // 比较左右子数组的元素,将较小的元素依次放入合并后的数组中
  while (i < left.length && j < right.length) {
    if (left[i] <= right[j]) {
      merged.push(left[i]);
      i++;
    } else {
      merged.push(right[j]);
      j++;
    }
  }

  // 将剩余的元素放入合并后的数组中
  while (i < left.length) {
    merged.push(left[i]);
    i++;
  }
  while (j < right.length) {
    merged.push(right[j]);
    j++;
  }

  return merged;
}

// 测试
const arr = [4, 2, 7, 5, 1, 6, 3, 8];
const sortedArr = mergeSort(arr);
console.log(sortedArr); // 输出 [1, 2, 3, 4, 5, 6, 7, 8]

算法步骤如下:

  1. 归并排序算法通过递归对一个待排序数组进行排序。
  2. 在每一层递归中,将数组一分为二,分别得到左右两个子数组。
  3. 继续递归调用归并排序算法,分别对左右两个子数组进行排序。
  4. 当子数组长度小于等于1时,递归出口,直接返回该子数组本身。
  5. 将两个有序的子数组合并成一个有序的数组。
  6. 合并过程中,使用两个指针分别指向左右两个子数组的元素,比较两个元素的大小,选择较小的元素放入合并后的数组,直到遍历完左右两个子数组。
  7. 将剩余的元素依次放入合并后的数组中。
  8. 返回合并后的数组作为结果。

下面是归并排序算法的流程图表示:

               [4,2,7,5,1,6,3,8]
             /                 \
      [4,2,7,5]              [1,6,3,8] 
       /     \                /     \
    [4,2]   [7,5]           [1,6]  [3,8] 
   /    \     /   \        /    \    /    \
 [4]   [2]   [7]   [5]    [1]  [6]  [3]  [8] 
   \    /     \   /        \    /    \    /
    [2,4]    [5,7]         [1,6]    [3,8] 
       \      /    \         /       \       
    [2,4,5,7]    [1,3,6,8]            
           \       /   
      [1,2,3,4,5,6,7,8]

在这个流程图中,每一层递归都将数组分成两部分,最后合并成一个有序的数组。

更多推荐

注入之SQLMAP(工具注入)

isqlmap是一个自动化的SQL注入工具,其主要功能是扫描,发现并利用给定的URL和SQL注入漏洞,其广泛的功能和选项包括数据库指纹,枚举,数据库提权,访问目标文件系统,并在获取操作权限时执行任意命令。希望这篇文章能让你不仅有一定的收获,而且可以愉快的学习,如果有什么建议,都可以留言和我交流sqlmap相关参数介绍-

广州华锐互动:利用VR复原文化遗址,沉浸式体验历史文物古迹的魅力

在过去的几十年里,科技发展飞速,为我们打开了无数新的视角和可能性。其中,虚拟现实(VirtualReality,简称VR)技术的崭新应用,为我们提供了一种全新的、近乎身临其境的体验历史的方式。本文将重点探讨VR技术在复原历史古迹方面的应用及其潜力。虚拟现实技术是一种可以创建和体验虚拟世界的计算机模拟系统。它利用计算机生

VR+中医骨伤学仿真情景实训教学|英途信息

首先,VR骨伤学虚拟实训教学可以突破地域限制。传统的实训教学需要学生亲身前往实地进行观察学习,但这常常受到时间、地点和费用等方面的限制。而通过虚拟现实技术,学生只需佩戴VR头盔,便可随时随地进行学习和实训,无需受到地理位置的限制,大大提高了学习的自由度和灵活性。其次,VR骨伤学虚拟实训教学可以提供更加真实的实践环境。在

VR全景算不算好的创业项目?有哪些特性?

现在是全民创业的时代,大家都在找创业项目,那么什么是好的创业项目呢?有人会问VR全景算不算创业好项目呢?一般情况下好的创业项目,发展前景和市场消费群体都是比较大的,市场需求大才能满足多数消费者的需求。现如今数字化时代,各个行业的实体商户已经离不开互联网的宣传推广了,加上之前遭受疫情的影响,很多老板也明白了线上宣传推广的

《数字图像处理-OpenCV/Python》连载(4)图像的读取与保存

《数字图像处理-OpenCV/Python》连载(4)图像的读取与保存本书京东优惠购书链接:https://item.jd.com/14098452.html本书CSDN独家连载专栏:https://blog.csdn.net/youcans/category_12418787.html第1章图像的基本操作为了方便初学

【Opencv入门到项目实战】(三):图像腐蚀与膨胀操作

文章目录1.腐蚀操作2.膨胀操作3.开运算和闭运算4.礼帽与黑帽5.梯度运算1.腐蚀操作腐蚀操作是图像处理中常用的一种形态学操作,我们通常用于去除图像中的噪声、分割连通区域、减小目标物体的尺寸等。腐蚀操作的原理是,在给定的结构元素下,遍历图像的每个像素,并将其值替换为该像素周围邻域内像素的最小值。结构元素控制了腐蚀的邻

python: excel假期时间提取统计

#encoding:utf-8#版权所有2023涂聚文有限公司#许可信息查看:#描述:#Author:geovindu,GeovinDu涂聚文.#IDE:PyCharm2023.1python311#Datetime:2023/9/37:04#User:geovindu#Product:PyCharm#Project:

C++虚函数剖析-继承,多继承和虚继承情况

tags:C++categories:C++写在前面前面分析了C++类内的虚指针和虚表,通过二级指针解引用的方式找到虚表,由此访问虚函数,相较于传统的死记硬背,我一直觉得学习编程时候能看到具体的/确切的输入输出结果,对于掌握某个知识点要更加有效,如果你只是知道了虚函数的原理,却又说不清楚虚函数是怎样寻址的,即其在类内具

哪些人适合申请浙大miniMBA项目?如果今年无望浙大MBA的几点建议

&nbsp;&nbsp;&nbsp;&nbsp;距离2024年MBA联考还有三个月左右的时间,对于广大浙大MBA项目的考生来说,事到如今似乎今年的联考结果已经越来越分明。还在犹豫要不要报考或者备考来不来得及的考生,如果本身基础不是很好,杭州达立易考教育就要泼一盆冷水了:恐怕接下来的时间大概率回天乏术,毕竟很少能有考生可

【三相有源电力滤波器】使用同步参考系控制的三相有源功率滤波器(Simulink)

💥💥💞💞欢迎来到本博客❤️❤️💥💥🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。⛳️座右铭:行百里者,半于九十。📋📋📋本文目录如下:🎁🎁🎁目录💥1概述📚2运行结果🎉3参考文献🌈4Simulink仿真实现💥1概述【三相有源电力滤波器】采用同步参考系控制的三相

如何在 Excel 中求平方根

需要在Excel中求一个数字的平方根吗?使用几个内置的Excel函数和公式可以轻松计算平方根。在本分步指南中,您将学习在Excel中计算平方根的5种不同方法,包括使用SQRT函数、POWER函数、指数公式、VBA代码和PowerQuery。跟随教程,掌握平方根计算并提高您的Excel技能。让我们深入了解一下吧!使用SQ

热文推荐