当前位置: 首页 > article >正文

漫画:什么是归并排序算法?

归并排序是建立在归并操作的一种高效的排序方法,该方法采用了分治的思想,比较适用于处理较大规模的数据,但比较耗内存,今天我们聊聊归并排序

一、排序思想

一天,小一尘和慧能坐在石头上,眺望着远方

image-20230212223830927

image-20230212223846275

image-20230212223859988

image-20210425154735224

image-20230212223930424

image-20230212223943221

分而治之: 分开来去治理

image-20230212223959308

image-20230212224011999

image-20230212224027406

归并即合并之意

慧能随手画了一张图解释了一下

image-20230212224048367

治:治理,这里就是将数组排序

image-20230212224101284

image-20230212224127250

image-20230212224143819

对于合并,其实非常简单,我只要不断地取出两个有序数组中比较小的那一个放在一个辅助数组中(通过比较),直到把两个有序数组中的元素取完

image-20230212224158909

image-20230212224219964

二、代码

image-20230212224239292

image-20230212224255908

一尘已经了解了师傅的固定套路了

既然是不断地分,那用递归就非常简单了,什么时候终止递归呢?递归到只有一个元素的时候。一尘随手写下了如下代码

image-20230212225129976

这里需要说明的是,center = (left + right) / 2 最好改成 center = left + (right - left) / 2,因为 left + right 有可能溢出。

很快,一尘写下了 merge 函数的代码

image-20230212225157452

image-20230212225217123

三、时间复杂度

image-20230212225306699

一尘想到:这个有点烧脑啊,元素个数为 n,运行时间是多少啊?递归,递归,再递归…

image-20230212225329890

师傅一下看出了一尘的心思

image-20230212225357296

image-20230212225412612

假设处理的数据规模大小为 N

运行时间设为:T(N)

① 当把 N 分为两半时,那么处理大小为 N/2 子数组花费时间为:T(N/2)

② 合并花费时间与数据规模成正比:N

所以处理规模大小为N的数据所需要花费两个大小为 N/2 的子数组加上合并花费的时间

即:T(N) = 2T(N/2) + N

对于 N = 1,T(1) = 1

image-20230212225638608

image-20230212225651102

image-20230212225711161

image-20230212225727920

image-20230212225743067

image-20230212225758088

四、稳定性

image-20230212225950515

image-20230212230011647

image-20230212230040545

此时太阳已经下山,一尘和师傅走在回家的路上,在路上,一尘脑子又想了一下归并排序的全过程

image-20230212230158300

更多排序算法文章

1. 漫画:什么是冒泡排序算法?

2. 漫画:什么是选择排序算法?

3. 漫画:什么是插入排序算法?

4. 漫画:什么是希尔排序算法?

5. 漫画:什么是归并排序算法?

6. 漫画:什么是快速排序算法?

7. 漫画:什么是堆排序算法?

8. 漫画:什么是基数排序算法?

9. 漫画:什么是外部排序?

10. 什么是计数排序?

11. 十大排序算法极简汇总篇

推荐阅读

下载破 2w+,在校生必看,《程序员内功修炼》第二版出炉

从双非到大厂,帅地写了一本原创PDF送给大家

一个帮你拿offer的校招网站

算法刷题路线(系统+全面)

作者简介:我是帅地,校招拿到过不少大厂offer,毕业去了腾讯研发岗,毕业半年整到人生第一个 100 万,目前专注于写大学规划 + 校招求职相关的内容,著有个人原创网站 PlayOffer。


http://www.kler.cn/a/1014.html

相关文章:

  • 《零基础Go语言算法实战》【题目 2-22】Go 调度器优先调度问题
  • 浅谈计算机网络01 | 计算机网络数据平面
  • MongoDB实践
  • 信息科技伦理与道德3:智能决策
  • springmvc的获取请求数据
  • 对智能的一种新理解
  • Adam优化器算法详解及代码实现
  • ubuntu不同版本的源(换源)(镜像源)(lsb_release -c命令,显示当前系统的发行版代号(Codename))
  • 【Android笔记85】Android之使用Camera和MediaRecorder录制视频
  • Java的jar包打包成exe应用
  • K8S集群之-ETCD集群监控
  • 有图解有案例,我终于把 Condition 的原理讲透彻了
  • 几个cve漏洞库查询网站-什么是CVE?常见漏洞和暴露列表概述
  • Android 自定义view优化方案
  • spring事务 只读此文
  • Go panic的学习
  • 初识C++需要了解的一些东西(2)
  • 从GPT到GPT-3:自然语言处理领域的prompt方法
  • 开源超级终端工具——WindTerm
  • Qt·Linux下Qt、Qml程序的打包
  • Linux(传输层二继续讲TCP)
  • 关于进制转换
  • 【C++】Google编码风格学习
  • 11广义表的基本概念和性质
  • mysql创建索引导致死锁,数据库崩溃,完美解决方案
  • 自训练和协同训练简述