【算法】快速排序1

题目

给定你一个长度为 𝑛的整数数列。 请你使用快速排序对这个数列按照从小到大进行排序。 并将排好序的数列按顺序输出。

输入格式 输入共两行,第一行包含整数 𝑛。 第二行包含 𝑛个整数(所有整数均在 1∼10^9范围内),表示整个数列。
输出格式

输出共一行,包含 𝑛 个整数,表示排好序的数列。
数据范围

1≤𝑛≤100000
输入样例:

5 3 1 2 4 5
输出样例:

1 2 3 4 5

来源:acwing算法基础 785. 快速排序


思路(注意事项)

选择基准值:取区间中间位置的元素作为基准值


题解

c 复制代码
#include<iostream>
using namespace std;

// 快速排序函数
void qsort(int a[], int l, int r)
{
    // 递归终止条件:如果左边界大于等于右边界,说明区间已经有序,直接返回
    if (l >= r) return;
    
    // 选择基准值:取区间中间位置的元素作为基准值
    // 这样可以避免最坏情况(例如数组已经有序时)的时间复杂度退化
    int x = a[(l + r) / 2];
    
    // 初始化两个指针:i 从左边界的前一个位置开始,j 从右边界的后一个位置开始
    int i = l - 1, j = r + 1;
    
    // 分区过程:将数组分为两部分,左边部分 <= 基准值,右边部分 >= 基准值
    while (i < j)
    {
        // 从左向右找到第一个 >= 基准值的元素
        do i++; while (a[i] < x);
        
        // 从右向左找到第一个 <= 基准值的元素
        do j--; while (a[j] > x);
        
        // 如果 i 和 j 没有相遇,交换这两个元素
        if (i < j) swap(a[i], a[j]);
    }
    
    // 递归排序左半部分:从 l 到 j
    qsort(a, l, j);
    
    // 递归排序右半部分:从 j + 1 到 r
    qsort(a, j + 1, r);
}

int main()
{
    // 输入数组的长度
    int n;
    cin >> n;
    
    // 定义数组并输入元素
    int a[n];
    for (int i = 0; i < n; i++)
        cin >> a[i];
    
    // 调用快速排序函数,对数组进行排序
    qsort(a, 0, n - 1);
    
    // 输出排序后的数组
    for (int i = 0; i < n; i++)
        cout << a[i] << " ";
    
    return 0;
}
相关推荐
爱思德学术几秒前
【SPIE出版】黄冈师范学院主办!第四届大数据、计算智能与应用国际会议(BDCIA 2026)
大数据·算法·数据分析·云计算·etl
洛水水2 分钟前
【力扣100题】40.二叉树中的最大路径和
算法·leetcode·深度优先
洛水水5 分钟前
【力扣100题】37.从前序与中序遍历序列构造二叉树
c++·算法·leetcode
zyq99101_17 分钟前
递归与动态规划实战代码解析
python·算法·蓝桥杯
蜡笔小马27 分钟前
08.C++设计模式-享元模式
c++·设计模式·享元模式
橘白31629 分钟前
rl笔记(一):策略梯度更新算法推导
人工智能·算法·机器人·强化学习
hhhhhaaa29 分钟前
多节点矩阵式任务系统:统一配置中心与动态规则引擎架构设计
后端·算法·架构
吃着火锅x唱着歌40 分钟前
LeetCode 739.每日温度
算法·leetcode·职场和发展
如竟没有火炬42 分钟前
去除重复字母——贪心+单调栈
开发语言·数据结构·python·算法·leetcode·深度优先
小侯不躺平.1 小时前
C++ Boost库【4】 --分词器的使用
c++·windows·microsoft