排序算法模板——归并,快排【C++】

embedded/2025/2/26 17:21:42/

前言

二者都是分治思想的体现,区别是归并是以整个数组的mid(下标的中间值)来分,分别将左右两个区间排好序,再合并;而快排是以数组中的一个数来划分,将小于等于这个数的放在该数左边,大于的放在右边。

ps.下面的代码中,归并排序使用传统int数组,快排使用vector数组,其实都是可以的,不过需要注意的是传统数组直接传数组名就相当于传地址了,但是vector数组需要使用引用&,否则是复制一个新数组作为参数;

归并排序 

#include <iostream>
using namespace std;
int N;void mergeSort(int q[], int l, int r) {if(l >= r) return;int mid = (l + r) >> 1;mergeSort(q, l, mid);mergeSort(q, mid + 1, r);int temp[N];int k = 0, i = l, j = mid + 1;while(i <= mid && j <= r) {if(q[i] <= q[j]) temp[k++] = q[i++];else temp[k++] = q[j++];}while(i <= mid) temp[k++] = q[i++];while(j <= r) temp[k++] = q[j++];for(int i = l, j = 0; i <= r; i++, j++) {q[i] = temp[j]; }
}int main () {cin >> N;int q[N];for(int i = 0; i < N; i++) {cin >> q[i];}mergeSort(q, 0, N - 1);for(int i = 0; i < N; i++) {cout << q[i] << ' ';}
}

  • 归并:先递归后合并;稳定;O(nlogn)

快速排序

#include <iostream>
#include <algorithm>
#include <vector>using namespace std;void quicksort(vector<int> &q, int l, int r) {if(l >= r) return;int x = q[(l + r) >> 1],i = l - 1, j = r + 1;while(i < j) {do i++; while(q[i] < x);do j--; while(q[j] > x);if(i < j) swap(q[i], q[j]);}quicksort(q, l, i);quicksort(q, i + 1, r);
}int main () {int n;cin >> n;vector<int>q(n);for(int i = 0; i < n; i++) {cin >> q[i];}quicksort(q, 0, n - 1);for(int i = 0; i < n; i++) {cout << q[i] << ' ';}
}

  • x可随机取值,但要注意最好不要取边界值,否则后续递归时可能造成死循环,比如上述代码就不能将x初始化为q[r](可以1,2为例,自己试试是否会死循环)
  • 快排:先排序后递归;不稳定;O(nlogn)

 

补充:参考了AcWing基础算法课中的讲解与模板,有兴趣可直接去AcWing官网查看


http://www.ppmy.cn/embedded/167311.html

相关文章

重构清洁想象,石头科技首创五轴仿生机械手打破传统清洁边界

2月25日&#xff0c;主题为“重构清洁想象”的石头科技2025发布会在上海天文馆正式召开。石头科技清洁产品BU总裁钱启杰在会上宣布&#xff0c;石头科技正式成为上海天文馆授权合作伙伴&#xff0c;希望借助航天科技到家庭科技的跨越&#xff0c;进一步简化家庭清洁工作&#x…

电商评论数据实现每秒百级评论数据的实时抓取

电商评论数据蕴含用户情感与产品改进方向。本文基于Go语言NSQ消息队列&#xff0c;实现每秒万级评论数据的实时抓取与情感分析。 1. ​系统架构与核心代码​ go package mainimport ("github.com/nsqio/go-nsq""encoding/json" )// 评论数据模型 type Com…

minio作为K8S后端存储

docker部署minio mkdir -p /minio/datadocker run -d \-p 9000:9000 \-p 9001:9001 \--name minio \-v /minio/data:/data \-e "MINIO_ROOT_USERjbk" \-e "MINIO_ROOT_PASSWORDjbjbjb123" \quay.io/minio/minio server /data --console-address ":90…

LLaMA中的微调方法

LoRA&#xff08;Low-Rank Adaptation&#xff09;是一种用于微调大型预训练模型的高效方法&#xff0c;特别适用于自然语言处理&#xff08;NLP&#xff09;任务。其核心思想是通过低秩分解来减少参数量&#xff0c;从而在保持模型性能的同时降低计算和存储成本。 关键点 低秩…

Starlink卫星动力学系统仿真建模第十讲-基于SMC和四元数的卫星姿态控制示例及Python实现

基于四元数与滑模控制的卫星姿态控制 一、基本原理 1. 四元数姿态表示 四元数运动学方程&#xff1a; 3. 滑模控制设计 二、代码实现&#xff08;Python&#xff09; 1. 四元数运算工具 import numpy as npdef quat_mult(q1, q2):"""四元数乘法""…

leetcode 2502. 设计内存分配器 中等

给你一个整数 n &#xff0c;表示下标从 0 开始的内存数组的大小。所有内存单元开始都是空闲的。 请你设计一个具备以下功能的内存分配器&#xff1a; 分配 一块大小为 size 的连续空闲内存单元并赋 id mID 。释放 给定 id mID 对应的所有内存单元。 注意&#xff1a; 多个…

10. docker nginx官方镜像使用方法

本文介绍docker nginx官方镜像使用方法&#xff0c;因为第一次用&#xff0c;在加上对docker也不是很熟&#xff0c;中间踩了一些坑&#xff0c;为了避免下一次用又踩坑&#xff0c;因此记录如下&#xff0c;也希望能够帮到其它小伙伴。 官方镜像页面&#xff1a;https://hub.d…

qt中QDebuge中文乱码的解决

qt的QDebuge中文乱码&#xff0c;我采用的下面的方案&#xff0c;直接在Windows的设置中修改&#xff0c;然后就OK了&#xff0c;记录一下。可能不同的开发环境不同吧&#xff0c;我用的是win11&#xff0c;按照下图设置&#xff0c;然后重启就OK了。