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

归并排序 图解 递归 + 非递归 + 笔记

前置知识:讲解019-算法笔试中处理输入和输出,讲解020-递归和master公式

  • (1)左部分排好序,右部分排好序,利用merge过程让左右整体有序
  • (2)merge过程:谁小拷贝谁,直到左右两部分所有的数字耗尽
  • (3)递归实现和非递归实现
  • (4)时间复杂度O(n*logn)
  • (5)需要辅助数组,所以额外空间复杂度O(n)
  • (6)归并排序为什么比O(n^2)的排序快?因为比较行为没有浪费!
  • (7)利用归并排序的便利性可以解决很多问题,例如归并分治

注意:有些资料说可以用原地归并排序,把额外空间复杂度变成O(1),不要浪费时间去学。因为原地归并排序确实可以省空间,但是会把复杂度变成O(n^2)

  • 对这个数组arr=[6,4,2,3,9,4] ,进行归并排序 

  • 挑其中一步来演示: 把[2,4,6]和[3,4,9]合并(merge)

最后再刷回原数组 

void merge(vector<int>& arr,int left, int mid, int right) {int n = right - left + 1;vector<int> help(n,0);int i = 0;int a = left;int b = mid + 1;while (a <= mid && b <= right) {help[i++] = arr[a] <= arr[b] ? arr[a++] : arr[b++];}// 左侧指针,右侧指针,必有一个越界,另一个不越界while (a <= mid) {help[i++] = arr[a++];}while (b <= right) {help[i++] = arr[b++];}for (i = 0; i <n; i++) { // 把 help 里面的数据重新刷回到原数组arrarr[i+left] = help[i];}
}

(1)归并排序递归版

// 递归方法
void mergeSort(vector<int>& arr, int left, int right) {if (left == right) return;int mid = (left + right) / 2;mergeSort(arr, left, mid);mergeSort(arr, mid + 1, right);merge(arr, left, mid, right);
}

(2)归并排序非递归版

// 归并排序非递归版
// 时间复杂度:O(n * logn)
// 空间复杂度:O(n)
void mergeSort2(vector<int>& arr) {int n = arr.size();// 一共发生O(logn)次for (int left, mid, right, step = 1; step < n; step <<= 1) {// 内部分组merge,时间复杂度:O(n)left = 0;while (left < n) {mid = left + step - 1;if (mid + 1 >= n) {// 已经没有右侧了break;}// 有右侧,求右侧的右边界right = min(left + (step << 1) - 1, n - 1);// left ... mid mid+1 ... right//								left ... mid mid+1 ... right//															 left ... mid mid+1 ... rightmerge(arr,left, mid, right);left = right + 1;}}	
}

完整代码:

#include <iostream>
#include <vector>
using namespace std;void merge(vector<int>& arr,int left, int mid, int right) {int n = right - left + 1;vector<int> help(n,0);int i = 0;int a = left;int b = mid + 1;while (a <= mid && b <= right) {help[i++] = arr[a] <= arr[b] ? arr[a++] : arr[b++];}// 左侧指针,右侧指针,必有一个越界,另一个不越界while (a <= mid) {help[i++] = arr[a++];}while (b <= right) {help[i++] = arr[b++];}for (i = 0; i <n; i++) { // 把 help 里面的数据重新刷回到原数组arrarr[i+left] = help[i];}
}/*归并排序递归版假设left...right一共 n 个数T(n) = 2 * T(n/2) + O(n)a = 2,b = 2,c = 1根据master公式,时间复杂度:O(n * logn)空间复杂度:O(n)
*/
// 递归方法
void mergeSort(vector<int>& arr, int left, int right) {if (left == right) return;int mid = (left + right) / 2;mergeSort(arr, left, mid);mergeSort(arr, mid + 1, right);merge(arr, left, mid, right);
}// 归并排序非递归版
// 时间复杂度:O(n * logn)
// 空间复杂度:O(n)
void mergeSort2(vector<int>& arr) {int n = arr.size();// 一共发生O(logn)次for (int left, mid, right, step = 1; step < n; step <<= 1) {// 内部分组merge,时间复杂度:O(n)left = 0;while (left < n) {mid = left + step - 1;if (mid + 1 >= n) {// 已经没有右侧了break;}// 有右侧,求右侧的右边界right = min(left + (step << 1) - 1, n - 1);// left ... mid mid+1 ... right//								left ... mid mid+1 ... right//															 left ... mid mid+1 ... rightmerge(arr,left, mid, right);left = right + 1;}}	
}int main() {vector<int> arr = { 6,4,2,3,9,4};int n = arr.size();mergeSort(arr, 0, n - 1);//mergeSort2(arr);for (int i = 0; i < n; i++) {cout << " " << arr[i] << " " << endl;}system("pause");return 0;
}

完整图:

参考和推荐视频:

算法讲解021【必备】归并排序_哔哩哔哩_bilibiliicon-default.png?t=N7T8https://www.bilibili.com/video/BV1wu411p7r7/?spm_id_from=333.999.list.card_archive.click&vd_source=a934d7fc6f47698a29dac90a922ba5a3

相关文章:

归并排序 图解 递归 + 非递归 + 笔记

前置知识&#xff1a;讲解019-算法笔试中处理输入和输出&#xff0c;讲解020-递归和master公式 (1)左部分排好序&#xff0c;右部分排好序&#xff0c;利用merge过程让左右整体有序(2)merge过程:谁小拷贝谁&#xff0c;直到左右两部分所有的数字耗尽(3)递归实现和非递归实现(4…...

2023 年最好的 Android 系统修复/刷机应用程序和软件

任何 Android 设备要顺利运行&#xff0c;其操作系统必须运行良好。幸运的是&#xff0c;对于大多数 Android 用户来说&#xff0c;这是不间断的。设备运行良好&#xff0c;打电话、共享文档等都没有问题。尽管如此&#xff0c;Android 操作系统可能会停止运行。这可能是由于特…...

Linux下内网穿透实现云原生观测分析工具的远程访问

&#x1f4d1;前言 本文主要是Linux下内网穿透实现云原生观测分析工具的远程访问设置的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是青衿&#x1f947; ☁️博客首页&#xff1a;CSDN主页放风讲故事 &…...

卡数据兼容性要求-M2M架构

EUM 应在生产 eUICC 过程中安装并初始化 ISD-R. eUICC 出厂后&#xff0c; ISD-R 应进入 GlobalPlatform Card Specification [GP CS]第 5.3 节中定义的生命周期状态 "PERSONALIZED". ISD-R 权力授予应遵循[GS RPT]附录 C 中的定义. EUM 应在 eUICC 生产过程中安装并…...

C++入门篇3(类和对象【重点】)

文章目录 C入门篇3&#xff08;类和对象【重点】&#xff09;1、面向过程和面向对象2、类的引入3、类的定义4、类的访问限定符及封装4.1、访问限定符4.2、封装 5、类的作用域6、类的实例化&#xff08;对象&#xff09;7、类对象模型7.1、类对象的存储方式7.2、结构体&#xff…...

【开源】基于Vue.js的生活废品回收系统的设计和实现

目录 一、摘要1.1 项目介绍1.2 项目详细录屏 二、研究内容三、界面展示3.1 登录注册3.2 资源类型&资源品类模块3.3 回收机构模块3.4 资源求购/出售/交易单模块3.5 客服咨询模块 四、免责说明 一、摘要 1.1 项目介绍 生活废品回收系统是可持续发展的解决方案&#xff0c;旨…...

Mysql配置主从复制-GTID模式

目录 主从复制 主从复制的定义 主从复制的原理 主从复制的优势 主从复制的形式 主从复制的模式 主从复制的类型 GTID模式 GTID的概念 GTID的优势 GTID的原理 GTID的配置 Mysql主服务器 ​编辑 Mysql从服务器 ​编辑 主从复制 主从复制的定义 是指把数据从一个…...

Flink之状态管理

Flink状态管理 状态概述状态分类 键控、按键分区状态概述值状态 ValueState列表状态 ListStateMap状态 MapState归约状态 ReducingState聚合状态 Aggregating State 算子状态概述列表状态 ListState联合列表状态 UnionListState广播状态 Broadcast State 状态有效期 (TTL)概述S…...

[Mac软件]Adobe Media Encoder 2024 V24.0.2免激活版

软件说明 使用Media Encoder&#xff0c;您将能够处理和管理多媒体。插入、转码、创建代理版本&#xff0c;并几乎以任何可用的格式输出。在应用程序中以单一方式使用多媒体&#xff0c;包括Premiere Pro、After Effects和Audition。 紧密整合 与Adobe Premiere Pro、After …...

Bytebase 2.11.0 - 支持 OceanBase Oracle 模式

&#x1f680; 新功能 支持 OceanBase Oracle 模式。支持设置 MySQL 在线变更参数。新增项目数据库查看者的角色。 &#x1f384; 改进 支持在项目中直接选择所有用户并为之添加角色。 调整了项目页面的布局。在 SQL 编辑器中通过悬浮面板展示表和列的详情。 &#x1faa6; …...

『CV学习笔记』文本识别算法CRNNSVTR介绍

文本识别算法CRNN&SVTR介绍 文章目录 一. 文本识别1.1. 文本识别方法介绍1.1.1. 规则文本识别1.1.2. 不规则文本识别1.2. CRNN算法原理1.2.1. CRNN基本网络结构1.3. SVTR算法原理二. 参考文献一. 文本识别 文本识别是OCR(Optical Character Recognition)的一个子任务,其…...

HaaS510开板式DTU真机连云:上报监测数据至阿里云物联网平台

背景 HaaS: Hardware as a Service。 HAAS510 是一种开板式 DTU &#xff0c;旨在为用户已开发好的设备快速增加 4G 连云能力的 4G CAT1 数传模块。它通过将模组与用户设备集成到一个外壳内&#xff0c;既保持设备的一体性&#xff0c;又降低重新开发 PCB 的时间消耗和模组开…...

贾扬清开源 AI 框架 Caffe | 开源英雄

【编者按】在开源与人工智能的灿烂星河里&#xff0c;贾扬清的名字都格外地耀眼。因为导师 Trevor Darrell 教授的一句“你是想多花时间写一篇大家估计不是很在意的毕业论文&#xff0c;还是写一个将来大家都会用的框架&#xff1f;”&#xff0c;学生贾扬清一头扎进了创 Caffe…...

【objectarx.net】使用公式自动更新表格项的内容

使用公式自动更新表格项的内容...

CSS 移动端 1px(线条/边框) 不同机型上显示粗细不同,解决办法

由于不同的手机有不同的像素密度导致的。如果移动显示屏的分辨率始终是普通屏幕的2倍&#xff0c;1px的边框在devicePixelRatio2的移动显示屏下会显示成2px&#xff0c;所以在高清瓶下看着1px总是感觉变胖了 <!DOCTYPE html> <html lang"en"> <head&g…...

vue3使用vuex的示例(模块化功能)

目录 1. store/index.ts 2. main.ts 3. App.vue调用 4. 如果删除moduleA的namespaced属性, 保留moduleB的namespaced:true 5. 则App.vue修改为: 1. store/index.ts 注意: 需要使用时带上模块名称的namespaced必须为true, 不写或者为false时调用时不需要写模块名称(获取st…...

Vatee万腾的科技决策力奇迹:Vatee科技决策力的独特之选

在金融投资的复杂领域中&#xff0c;Vatee万腾以其独特的科技决策力创造了一场真正的奇迹。这不仅是一种引领投资者走向成功的选择&#xff0c;更是一种开启新时代的科技决策奇迹。 Vatee的科技决策力背后蕴藏着强大的智慧和创新。通过大数据分析、智能算法的运用&#xff0c;V…...

ai技术是怎么换脸的,实现原理是什么,有那些软件

人工智能&#xff08;AI&#xff09;在近年来的迅猛发展中&#xff0c;带来了许多令人惊叹的技术创新&#xff0c;其中之一就是人工智能换脸技术。这项技术通过深度学习和图像处理的手段&#xff0c;使得用户可以将自己的面孔替换成其他人物&#xff0c;引发了广泛的讨论和应用…...

在IDEA中使用maven项目总结

一 什么是maven Maven本身也是Java写的&#xff0c;他是一款服务于Java平台的自动化构建工具 Maven是一个项目管理工具&#xff0c;旨在简化软件项目的构建、依赖管理和项目信息管理。它使用基于项目对象模型&#xff08;Project Object Model&#xff0c;POM&#xff09;的…...

oracle备份一个表需要做的操作

在 Oracle 中备份一个表可以通过以下步骤完成&#xff0c;包括备份表结构&#xff08;DDL&#xff09;和备份表数据&#xff08;DML&#xff09;&#xff1a; 备份表结构&#xff08;DDL&#xff09;&#xff1a; 使用 CREATE TABLE AS SELECT&#xff1a; 创建一个新表&#…...

ZVS和ZCS到底怎么选?从无线充电到服务器电源,聊聊软开关技术的选型实战

ZVS与ZCS技术选型实战&#xff1a;从无线充电到服务器电源的高效设计指南 在追求极致效率的现代电源系统中&#xff0c;软开关技术早已从实验室走向量产。当我们拆解一款氮化镓快充、观察服务器机柜的电源模块&#xff0c;或是测试无线充电板的温升时&#xff0c;ZVS&#xff0…...

静态分析失效了?SITS2026实测数据:92.7%的隐蔽依赖漏洞仅靠AI图神经网络可检出,你还在用正则?

第一章&#xff1a;SITS2026演讲&#xff1a;AI代码依赖分析 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026主会场&#xff0c;来自MIT与GitHub联合实验室的研究团队首次公开演示了基于大语言模型的静态代码依赖图实时重构引擎——DepGraph-LLM。该系统不依赖传统…...

告别费马小定理!用线性递推O(n)批量求逆元,组合数计算效率翻倍(附C++代码)

告别费马小定理&#xff01;用线性递推O(n)批量求逆元&#xff0c;组合数计算效率翻倍&#xff08;附C代码&#xff09; 在算法竞赛和编程面试中&#xff0c;组合数计算是一个高频出现的难题。想象一下这样的场景&#xff1a;你正在参加ACM比赛&#xff0c;面对一道需要计算大量…...

Grafana Tempo介绍(分布式追踪后端系统,用于存储和查询追踪数据)OpenTelemetry、OTLP、无索引、TraceID查询、低成本、依赖对象存储、Exemplars

文章目录一文读懂 Tempo&#xff1a;云原生时代的分布式追踪后端一、什么是 Tempo&#xff1f;二、Tempo 在可观测性体系中的位置三、Tempo 的核心设计理念1. 无索引&#xff08;Index-free&#xff09;为什么这么设计&#xff1f;2. 对象存储优先3. 与 Metrics 强关联&#xf…...

Markdown转docx 保留Latex渲染样式

需求分析 Markdown转docx有大量公式。包括行内公式和行间公式Office 自带的数学与 Latex的渲染样式存在差异。本文倾向于使用Latex的渲染样式轻量调整。转换后仅做轻微的调整&#xff0c;不再编辑公式。 选择方案 主要编辑在Markdown&#xff0c;使用Latex渲染样式&#xff…...

React 大师级思考:如何在不断演变的 Web 标准中保持 React 项目的长期可维护性与扩展性

React 大师级思考&#xff1a;如何在不断演变的 Web 标准中保持 React 项目的长期可维护性与扩展性各位代码的朝圣者&#xff0c;各位在组件海洋中溺水又被救起的勇士们&#xff0c;欢迎来到今天这场关于“如何让 React 项目活过 10 年”的讲座。我知道你们在想什么。你们在想&…...

Java的java.util.HexFormat分隔符设置与十六进制字符串的可读性增强

Java十六进制数据处理新选择&#xff1a;HexFormat的可读性优化 在二进制数据处理、加密算法或网络通信中&#xff0c;十六进制字符串的解析与生成是常见需求。传统方法如Integer.toHexString()生成的连续字符缺乏分隔符&#xff0c;可读性较差。Java 17引入的java.util.HexFo…...

从‘贴图’到‘氛围’:手把手教你用Unity Skybox Shader打造动态昼夜循环

从静态到动态&#xff1a;Unity Skybox Shader的昼夜循环艺术 在游戏开发的世界里&#xff0c;天空从来不只是背景。它是情绪的载体&#xff0c;是时间的见证者&#xff0c;更是沉浸感的第一道门槛。当我们谈论开放世界的真实感&#xff0c;或是叙事游戏的氛围营造&#xff0c;…...

背靠背VSC直流母线电压控制与同步发电机并网发散问题:原理、分析与解决方案

背靠背VSC直流母线电压控制与同步发电机并网发散问题:原理、分析与解决方案 摘要 背靠背电压源换流器(Back-to-Back VSC)是现代柔性直流输电和新能源并网系统的核心设备。在实际工程调试中,经常出现一个令人困扰的现象:当采用“三相电源-VSC-直流母线-VSC-三相电源”的背…...

香瓜树莓派RP2350之USB虚拟串口驱动开发实战

1. 硬件准备与环境搭建 第一次接触树莓派RP2350开发板时&#xff0c;我被它小巧的体积和强大的功能惊艳到了。这块板子虽然只有信用卡大小&#xff0c;但内置双核ARM Cortex-M0处理器&#xff0c;主频高达133MHz&#xff0c;特别适合用来做嵌入式开发。要实现USB虚拟串口功能&…...