[LeetBook]【学习日记】排序算法——归并排序

主要思想

  1. 归并排序是一种分治算法,其排序过程包括分和治
  2. 分是指将要排序的序列一分为二、二分为四,直到单个序列中只有一个数
  3. 治是指在分完后,将每两个元素重新组合,四合为二、二合为一,最终完成排序

    图片作者:Krahets
    链接:https://leetcode.cn/leetbook/read/illustration-of-algorithm/p5l0js/

代码框架

cpp 复制代码
void mergeSort(vector<int> nums, int low, int high) {
        if(low>=high) return;//直到序列中只有单个元素
        //分
		...
        //治
		...
        }
    }
  1. 分:也就是一分为二的过程,类似二分查找,使用两个递归一次传入一半的序列
  2. 治:在分完后,新建一个临时数组,将要合并的内容先存储起来,然后使用两个下标从两个要合并的序列的开始处进行遍历比较,依次将正确顺序的元素存入原数组,当有一个下标超出其要遍历的序列时,直接将其他序列剩下的内容合并到原数组的后面

完整代码

cpp 复制代码
在这里插入代码片void mergeSort(vector<int>& nums, int low, int high) {
        if(low>=high) return;
        int mid=(high+low)/2;
        //分
        mergeSort(nums, low, mid);
        mergeSort(nums, mid+1, high);
        //治
        vector<int> temp;
        temp.assign(nums.begin()+low, nums.begin()+high+1);
        int i=0, j=mid-low+1;//用于在 temp 中遍历
        for(int x=low; x<=high; ++x){
            if(i==mid-low+1) nums[x]=temp[j++];
            else if(j==high-low+1 || temp[j]>=temp[i]) nums[x]=temp[i++];
            else nums[x]=temp[j++];
        }
    }

此处的>=保证排序结果稳定。

cpp 复制代码
else if(j==high-low+1 || nums[j]>=nums[i]) nums[x]=temp[i++];

相关题目

148. 排序链表
LCR 170. 交易逆序对的总数

相关推荐
星火开发设计5 小时前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
Gorgous—l6 小时前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
Hello_Embed6 小时前
libmodbus 移植 STM32(基础篇)
笔记·stm32·单片机·学习·modbus
●VON7 小时前
Flutter for OpenHarmony 21天训练营 Day03 总结:从学习到输出,迈出原创第一步
学习·flutter·openharmony·布局·技术
香芋Yu7 小时前
【大模型教程——第四部分:大模型应用开发】第1章:提示工程与上下文学习 (Prompt Engineering & ICL)
学习·prompt
LYS_06187 小时前
寒假学习10(HAL库1+模数电10)
学习
runningshark8 小时前
【项目】示波器学习与制作
学习
€8118 小时前
Java入门级教程24——Vert.x的学习
java·开发语言·学习·thymeleaf·数据库操作·vert.x的路由处理机制·datadex实战
自可乐8 小时前
n8n全面学习教程:从入门到精通的自动化工作流引擎实践指南
运维·人工智能·学习·自动化