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

C++归并排序详解以及代码实现

1. 介绍

归并排序(Merge Sort)是一种采用分治法(Divide and Conquer)策略的排序算法。该算法首先将已有序的子序列合并,得到完全有序的序列。在归并排序中,合并操作是将两个有序表合并成一个有序表的过程。

归并排序的原理是将数组不断分成两半,直到每个子数组只有一个元素,然后将这些子数组合并成一个有序的数组。合并操作需要两个子数组都是有序的,因此归并排序需要先对数组进行分解,然后再进行合并。

以下是归并排序的实现步骤:

  1. 将待排序的数组不断分成两半,直到每个子数组只有一个元素。这一步被称为分解。
  2. 对每个子数进行排序,可以使用任何有效的排序算法。这一步被称为求解。
  3. 将所有已排序的子数组合并成一个有序的数组。这一步被称为合并。

归并排序的时间复杂度是 O(n log n),其中 n 是数组的大小。这是因为它需要将数组分解成两半,然后再合并成一个有序的数组。归并排序的空间复杂度是 O(n),因为在合并过程中需要额外的空间来存储临时变量。

2. 代码实现

#include <iostream>  
using namespace std;  // 归并操作,将有序数组a和b合并成一个有序数组c  
void merge(int a[], int b[], int c[], int m, int n) {  int i = 0, j = 0, k = 0; // i、j、k分别指向数组a、b、c的起始位置  while (i < m && j < n) { // 比较a和b中的元素,将较小的元素放入c中  if (a[i] <= b[j]) {  c[k++] = a[i++];  } else {  c[k++] = b[j++];  }  }  while (i < m) { // 将数组a中剩余的元素放入c中  c[k++] = a[i++];  }  while (j < n) { // 将数组b中剩余的元素放入c中  c[k++] = b[j++];  }  
}  // 归并排序函数,将数组a中的元素进行排序  
void mergeSort(int a[], int n) {  if (n <= 1) { // 如果数组只有一个元素或为空,直接返回  return;  }  int mid = n / 2; // 计算数组的中间位置  int left[mid]; // 存储数组a左边部分的元素  int right[n - mid]; // 存储数组a右边部分的元素  for (int i = 0; i < mid; i++) { // 将数组a左边部分的元素放入left数组中  left[i] = a[i];  }  for (int i = mid; i < n; i++) { // 将数组a右边部分的元素放入right数组中  right[i - mid] = a[i];  }  mergeSort(left, mid); // 对left数组进行归并排序  mergeSort(right, n - mid); // 对right数组进行归并排序  merge(left, right, a, mid, n - mid); // 将left和right两个有序数组合并成一个有序数组a  
}  // 测试归并排序函数  
int main() {  int a[] = {38, 27, 43, 36, 16, 25, 6, 22}; // 待排序的数组  int n = sizeof(a) / sizeof(a[0]); // 数组的大小  mergeSort(a, n); // 对数组进行归并排序  for (int i = 0; i < n; i++) { // 输出排序后的数组元素  cout << a[i] << " ";  }  cout << endl;  return 0;  
}

上述代码实现了一个基于分治法的排序算法——归并排序,总结如下:

  1. 归并排序将数组不断分成两半,直到每个子数组只有一个元素。然后对每个子数组进行排序,最后将所有已排序的子数组合并成一个有序的数组。
  2. merge函数实现了合并操作,将两个有序的数组合并成一个有序的数组。
  3. mergeSort函数是归并排序的主要实现。首先判断数组长度,如果只有一个元素或为空,直接返回。然后计算中间位置,将数组分成左右两部分。接着对左右两部分递归地进行归并排序,最后调用merge函数将两个有序数组合并成一个有序数组。
  4. main函数中,定义了一个待排序的数组a,然后调用mergeSort函数对其进行归并排序。最后输出排序后的数组元素。
  5. 时间复杂度为O(n log n),空间复杂度为O(n)。

相关文章:

C++归并排序详解以及代码实现

1. 介绍 归并排序&#xff08;Merge Sort&#xff09;是一种采用分治法&#xff08;Divide and Conquer&#xff09;策略的排序算法。该算法首先将已有序的子序列合并&#xff0c;得到完全有序的序列。在归并排序中&#xff0c;合并操作是将两个有序表合并成一个有序表的过程。…...

springboot整合JPA 多表关联 :一对多 多对多

补充一下自定义SQL 这是连表查询&#xff0c;可以任意查出字符&#xff0c;用Map接收 Testvoid test3() {JPAQueryFactory jpaQueryFactory new JPAQueryFactory(em);QStudent student QStudent.student;QMessage message QMessage.message;//constructor(StuMesDto.class, …...

Python 数据分析 Matplotlib篇 plt.rcParams 字典(第5讲)

Python 数据分析 Matplotlib篇 plt.rcParams字典(第5讲)         🍹博主 侯小啾 感谢您的支持与信赖。☀️ 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ�…...

DeamonSet详解

目录 1.1 何为DaemonSet 1.2 DaemonSet 的 API 对象的定义 1.3 DaemonSet实践 1.3.1 创建 DaemonSet 对象 1.3.2 查看 DaemonSet 对象 1.3.3 DaemonSet 版本管理 1.3.4 DaemonSet 的容器镜像版本到 v2.2.0 1.1 何为DaemonSet 介绍DaemonSet我们先来思考一个问题&#x…...

TwIST算法MALTLAB主程序详解

TwIST算法MALTLAB主程序详解 关于TwIST算法的具体原理可以参考&#xff1a; 链接: https://ieeexplore.ieee.org/abstract/document/4358846 链接: https://blog.csdn.net/jbb0523/article/details/52193209 该算法的MATLAB源代码&#xff1a; 链接: http://www.lx.it.pt/~bi…...

Flutter 三: Dart

1 数据类型 数字(number) int double 字符串转换成 num int.parse(“1”) double.parse(“1”);double 四舍五入保留两位小数 toStringAsFixed(2) 返回值为stringdouble 直接舍弃小数点后几位的数据 可使用字符串截取的方式 字符串(string) 单引号 双引号 三引号三引号 可以输…...

redis基本用法学习(C#调用FreeRedis操作redis)

FreeRedis属于常用的基于.net的redis客户端&#xff0c;EasyCaching中也提供适配FreeRedis的包。根据参考文献4中的说法&#xff0c;FreeRedis和CsRedis算是近亲&#xff08;都是GitHub中账号为2881099下的开源项目&#xff09;&#xff0c;因此其用法特别相似。FreeRedis的主要…...

Postman接口测试(超详细整理)

常用的接口测试工具主要有以下几种 Postman&#xff1a;简单方便的接口调试工具&#xff0c;便于分享和协作。具有接口调试&#xff0c;接口集管理&#xff0c;环境配置&#xff0c;参数化&#xff0c;断言&#xff0c;批量执行&#xff0c;录制接口&#xff0c;Mock Server, …...

【深入解析spring cloud gateway】12 gateway参数调优与分析

本节主要对网关主要的一些参数做一些解释说明&#xff0c;并用压测工具测试一下网关的接口&#xff0c;通过压测来验证参数配置是否合理 一、连接池参数 参数示例 spring:application:name: gatewaycloud:gateway:# http连接设置httpclient:# 全局的响应超时时间&#xff0c…...

Java继承,父类没有无参构造方法时,子类必须要显式调用父类的构造方法

在Java中&#xff0c;如果一个类没有定义任何构造函数&#xff0c;那么编译器会默认为这个类提供一个无参的构造函数。 这个隐式的构造函数在继承的时候&#xff0c;子类会在自己的构造方法里面默认的调用这个构造函数。 但是&#xff0c;如果我们在父类中定义了一个有参构造…...

Ubuntu 20.04使用Livox Mid-360

参考文章&#xff1a; Ubuntu 20.04使用Livox mid 360 测试 FAST_LIO-CSDN博客 一&#xff1a;Livox mid 360驱动安装与测试 前言&#xff1a; Livox mid360需要使用Livox-SDK2&#xff0c;而非Livox-SDK&#xff0c;以及对应的livox_ros_driver2 。并需要修改FAST_LIO中部…...

C语言之冒泡排序

其实排序有很多的方法&#xff0c;比如&#xff1a;冒泡排序&#xff0c;插入排序&#xff0c;快速排序&#xff0c;归并排序&#xff0c;选择排序等。今天来讲一下最简单的排序&#xff1a;冒泡排序。这种排序的方法效率极其低下。 假设有一个整型数组&#xff1a; int arr[…...

在Linux上安装NVM(Node Version Manager)

在Linux系统上&#xff0c;使用NVM&#xff08;Node Version Manager&#xff09;是管理和切换Node.js版本的一种便捷方式。以下是在Linux上安装NVM的步骤&#xff1a; 1. 下载并安装NVM 使用curl或wget下载并运行NVM的安装脚本。选择一种方式执行以下命令之一&#xff1a; …...

常用两种Linux命令生成器

在Linux中&#xff0c;可以使用多种命令来生成随机密码。以下是其中两种常用的命令&#xff1a; 1.pwgen&#xff1a;这个命令可以生成随机、无意义的但容易发音的密码。生成的密码可以只包含小写字母、大小写混合或数字。大写字母和数字会以一种便于记忆的方式放置&#xff0…...

【OAuth2】授权框架的四种授权方式详解

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《OAuth 2》。&#x1f3af;&#x1f3af; &#x1…...

AI数字人不间断直播是什么?数字人直播带货如何搭建?

随着电商行业的崛起&#xff0c;数字人直播成为了最为热门的直播方式之一。数字人直播利用AI技术创建出的数字人进行直播&#xff0c;给观众带来了全新的视觉体验。 一、AI数字人无限播&#xff08;数字人SaaS系统VX&#xff1a;zhibo175&#xff09;是什么&#xff1f; AI数字…...

真菌基因组研究高分策略(二):比较基因组揭示寄主外生菌根真菌基因组的动态进化

在表征外生菌根&#xff08;ECM&#xff09;真菌的“共生工具包”方面的研究已经取得了重大进展&#xff0c;但宿主特异性如何被编码到ECM真菌基因组中仍知之甚少。2021年发表于《New Phytologist》期刊的文章对ECM真菌宿主特异性和通用性进行了比较基因组分析&#xff0c;重点…...

uni-app之HelloWorld实现

锋哥原创的uni-app视频教程&#xff1a; 2023版uniapp从入门到上天视频教程(Java后端无废话版)&#xff0c;火爆更新中..._哔哩哔哩_bilibili2023版uniapp从入门到上天视频教程(Java后端无废话版)&#xff0c;火爆更新中...共计23条视频&#xff0c;包括&#xff1a;第1讲 uni…...

CVE-2023-49898 Apache incubator-streampark 远程命令执行漏洞

项目介绍 Apache Flink 和 Apache Spark 被广泛用作下一代大数据流计算引擎。基于大量优秀经验结合最佳实践&#xff0c;我们将任务部署和运行时参数提取到配置文件中。这样&#xff0c;带有开箱即用连接器的易于使用的 RuntimeContext 将带来更轻松、更高效的任务开发体验。它…...

即将来临的2024年,汽车战场再起波澜?

我们来简要概况一下11月主流车企的销量表现&#xff1a; 根据数据显示&#xff0c;11月吉利集团总销量29.32万辆&#xff0c;同比增长28%。这在当月国内主流车企中综合实力凌厉&#xff0c;可谓表现得体。而与吉利直接竞争的比亚迪&#xff0c;尽管数据未公布&#xff0c;但我们…...

源代码论文分享|基于Spring Boot的装饰工程管理系统!

做工程管理系统的同学&#xff0c;真的别一开始就硬啃空白项目。 尤其是装饰工程这种题目&#xff0c;看起来只是“管理系统”&#xff0c;但真写起来会发现&#xff1a;客户信息、工程项目、材料、施工进度、人员安排、费用统计……每一块都能展开。如果没有一个完整项目做参…...

Android音视频应用开发中的性能与功耗优化策略

引言 随着移动设备的普及和5G网络的推进,Android音视频应用(如视频会议、直播平台)已成为日常生活和工作的重要组成部分。然而,这些应用往往面临性能瓶颈(如卡顿、延迟)和功耗过高(如电池快速耗尽)的问题。作为一名Android音视频应用开发工程师,掌握性能优化和功耗优…...

30秒上手AI视频插帧:用Flowframes让视频帧率翻倍的终极指南

30秒上手AI视频插帧&#xff1a;用Flowframes让视频帧率翻倍的终极指南 【免费下载链接】flowframes Flowframes Windows GUI for video interpolation using DAIN (NCNN) or RIFE (CUDA/NCNN) 项目地址: https://gitcode.com/gh_mirrors/fl/flowframes 想要让普通视频瞬…...

保姆级教程:为Ultralytics YOLOv8 v8.0+ 添加mAP75和mAP90输出(附完整代码与验证方法)

深度优化YOLOv8评估体系&#xff1a;实战添加mAP75与mAP90指标全指南 当目标检测模型的mAP50达到80%以上时&#xff0c;研究者常陷入性能提升的瓶颈期。此时&#xff0c;引入mAP75和mAP90等更严格的评估指标&#xff0c;能有效区分"优秀"与"卓越"模型的边界…...

从warmup_csaw_2016看栈溢出利用的本质:绕过NX/ASLR?不,这次我们先学‘计算’

从warmup_csaw_2016看栈溢出利用的本质&#xff1a;计算的艺术 在二进制安全领域&#xff0c;栈溢出常被初学者视为"魔法攻击"——只需覆盖返回地址就能获得控制权。但当我们剥开NX/ASLR等现代保护机制的外衣&#xff0c;会发现精确计算才是漏洞利用的永恒核心。2016…...

如何在EVE Online中利用Pyfa实现舰船配装效率翻倍?

如何在EVE Online中利用Pyfa实现舰船配装效率翻倍&#xff1f; 【免费下载链接】Pyfa Python fitting assistant, cross-platform fitting tool for EVE Online 项目地址: https://gitcode.com/gh_mirrors/py/Pyfa 如果你是一位EVE Online玩家&#xff0c;是否曾经为游戏…...

【YOLO目标检测全栈实战】33 模型部署的终极形态:ONNX Runtime + TensorRT EP 跨平台推理

还记得上周帮一家做边缘计算盒子的客户调优时,他们遇到一个典型问题:同一份ONNX模型,在Windows服务器上用TensorRT跑出了5ms的推理延迟,可部署到客户的ARM工控机上,却只能用CPU硬扛,延迟直接飙到80ms。 客户老板当场拍桌子:“你们这模型是不是分三六九等?”我拆开部署…...

开发AI助手微服务时利用Taotoken实现模型的热切换与降级

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 开发AI助手微服务时利用Taotoken实现模型的热切换与降级 在构建对外提供AI对话能力的微服务时&#xff0c;服务的稳定性和连续性至…...

独立开发者如何利用Taotoken Token Plan套餐优化项目成本

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 独立开发者如何利用Taotoken Token Plan套餐优化项目成本 对于独立开发者或小型项目团队而言&#xff0c;在拥抱大模型能力的同时&…...

独立开发者利用Taotoken Token Plan套餐实现个人项目的长期成本规划

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 独立开发者利用Taotoken Token Plan套餐实现个人项目的长期成本规划 对于独立开发者或小型工作室而言&#xff0c;运营多个集成大语…...