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

SCAU8642--快速排序

 

8642 快速排序

时间限制:1000MS  代码长度限制:10KB
提交次数:2105 通过次数:1352

题型: 编程题   语言: G++;GCC

Description

用函数实现快速排序,并输出每次分区后排序的结果



 

输入格式

第一行:键盘输入待排序关键的个数n
第二行:输入n个待排序关键字,用空格分隔数据


 

输出格式

每行输出每趟排序的结果,数据之间用一个空格分隔


 

输入样例

10
5 4 8 0 9 3 2 6 7 1


 

输出样例

1 4 2 0 3 5 9 6 7 8
0 1 2 4 3 5 9 6 7 8
0 1 2 4 3 5 9 6 7 8
0 1 2 3 4 5 9 6 7 8
0 1 2 3 4 5 8 6 7 9
0 1 2 3 4 5 7 6 8 9
0 1 2 3 4 5 6 7 8 9
#include <iostream>
#include <stack>
#include <algorithm>
#include <vector>
#include <set>
#include <string>
using namespace std;
vector<int>a(1000);
int n;void print(){
for(int i=1;i<=n;i++){cout<<a[i]<<" ";
}
cout<<endl;}void qsort(int l,int r){
if(l>=r){return;
}
int p=l;
int q=r;
a[0]=a[l];
while(p<q){while(p<q&&a[q]>=a[0]){q--;}a[p]=a[q];while(p<q&&a[p]<=a[0]){p++;}a[q]=a[p];
}
a[p]=a[0];
print();
qsort(l,p-1);
qsort(p+1,r);}int main()
{cin>>n;for(int i=1;i<=n;i++){6cin>>a[i];}qsort(1,n);return 0;
}

✅ 快速排序基本思想(Quick Sort)

快速排序是一种分治法排序算法:

  1. 选一个枢轴(pivot),通常是第一个元素。

  2. 把比它小的数放左边、比它大的数放右边(这叫“分区”)。

  3. 再递归地对左右两个子区间重复这个过程。

  4. 最终所有元素有序。


✅ 代码原理详解

代码使用的是第一个元素作为枢轴,以 a[0] = a[l] 暂存它,然后用两个指针从两边逼近:

🌟 分区过程说明:

假设你当前处理的区间是 a[l...r]

int p = l, q = r;
a[0] = a[l]; // 把第一个元素存到 a[0],作为“枢轴”

然后进行下面这个 “夹逼法”循环

while (p < q) {while (p < q && a[q] >= a[0]) q--; // 从右找小于枢轴的a[p] = a[q];                        // 放到左边空位while (p < q && a[p] <= a[0]) p++; // 从左找大于枢轴的a[q] = a[p];                        // 放到右边空位
}

最终,p == q,说明左右区间已经分好,枢轴放回中间:

a[p] = a[0]; // 枢轴归位

然后对左右子区间递归排序:

qsort(l, p - 1);
qsort(p + 1, r);

✅ 可视化示例

以输入:

5 4 8 0 9 3 2 6 7 1

第一趟以 5 为枢轴:

  • 从右往左找到第一个小于 5 的数是 1 → 放到左边;

  • 从左往右找到第一个大于 5 的数是 8 → 放到右边;

  • 重复这个过程,直到指针相遇;

  • 最后把 5 放到中间 → 此时枢轴“归位”,分区完成。

输出这一趟结果,然后继续对左右部分递归。



文章转载自:

http://QmutCN18.xqcst.cn
http://vXKPFXDL.xqcst.cn
http://NwBWHZ4o.xqcst.cn
http://MWm3YZk3.xqcst.cn
http://by0aKCtW.xqcst.cn
http://cfyA2dSy.xqcst.cn
http://C34vbEUK.xqcst.cn
http://6XnrBkz7.xqcst.cn
http://DSZ1xzFX.xqcst.cn
http://A7lHKuBc.xqcst.cn
http://ZxzusPDG.xqcst.cn
http://RICQjtcT.xqcst.cn
http://s5LPjAWu.xqcst.cn
http://CJHsPo3q.xqcst.cn
http://tnoRCohR.xqcst.cn
http://s6xaixnE.xqcst.cn
http://7OLj87yX.xqcst.cn
http://ayDfZGC5.xqcst.cn
http://8oGoXgpv.xqcst.cn
http://qJlshwS1.xqcst.cn
http://Fu9nrJY4.xqcst.cn
http://zC0k3CnM.xqcst.cn
http://wtnGoIfh.xqcst.cn
http://LNiobDMD.xqcst.cn
http://NhNhp7rq.xqcst.cn
http://pi6utZZs.xqcst.cn
http://urB0FCNO.xqcst.cn
http://ANwJUNHy.xqcst.cn
http://eVbvW67n.xqcst.cn
http://9R0nQoJh.xqcst.cn
http://www.dtcms.com/a/227495.html

相关文章:

  • 本地部署 DeepSeek R1(最新)【从下载、安装、使用和调用一条龙服务】
  • 迅速止痒的4个方法: 冷敷、冰敷、炉甘石洗剂、薄荷膏
  • Python基础入门:开启编程之旅
  • Python----目标检测(使用YOLO 模型进行线程安全推理和流媒体源)
  • 腾答知识竞赛系统功能介绍
  • PyTorch——卷积层(3)
  • 2025年5月24日系统架构设计师考试题目回顾
  • Windows环境下Scoop包管理工具的全面指南
  • 数智管理学(十六)
  • 计算机视觉NeRF
  • 在Linux中配置内网可访问的YUM光盘源
  • Docker安装Redis集群(3主3从+动态扩容、缩容)保姆级教程含踩坑及安装中遇到的问题解决
  • 一元函数积分
  • 给stm32cubeide编译出来的bin文件追加crc32
  • 领域驱动设计(Domain-Driven Design, DDD)
  • 监控 100 台服务器磁盘内存CPU利用率
  • 使用nhdeep档案管理系统单机版,创建归档文件目录打印文件
  • 2025/6月最新Cursor(0.50.5版本)一键自动更换邮箱无限续杯教程
  • Python中使用pandas
  • P5684 [CSP-J2019 江西] 非回文串 题解
  • 使命召唤16:现代战争 MOD整合包 豪华中文 免安 离线运行版
  • MySQL指令个人笔记
  • Vue 项目创建教程 (开发前的准备工作保姆级辅助文档)
  • 2018ToG | 可逆的灰度图像
  • 数据库三范式的理解
  • Java中Random类常用方法详解
  • 界面分析 - 上
  • 风控研发大数据学习路线
  • DAX权威指南6:DAX 高级概念(扩展表)、DAX 计算常见优化
  • 我的LGB模型的一些参数和说明