当前位置: 首页 > 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://www.lqws.cn/news/73351.html

相关文章:

  • 计算机视觉---深度学习框架(Backbone、Neck、Head)
  • 每日算法-250602
  • Windows+VSCode搭建小智(xiaozhi)开发环境
  • 开源的JT1078转GB28181服务器
  • PDF 转 HTML5 —— HTML5 填充图形不支持 Even-Odd 奇偶规则?(第一部分)
  • 【Spring】RAG 知识库基础
  • Axure 基础入门
  • 50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Form Wave(表单label波动效果)
  • 自主设计一个DDS信号发生器
  • 每天掌握一个Linux命令 - hping3
  • 工作流引擎-16-开源审批流项目之 整合Flowable官方的Rest包
  • NiceGUI 是一个基于 Python 的现代 Web 应用框架
  • Windows10-ltsc-2019 使用 PowerShell 安装安装TranslucentTB教程(不通过微软商店安装)
  • Qt概述:基础组件的使用
  • 动态类型语言和静态类型语言
  • 【MySQL基础】库的操作:创建、删除与管理数据库
  • [ Qt ] | 与系统相关的操作(一):鼠标相关事件
  • 分布式锁优化:使用Lua脚本保证释放锁的原子性问题
  • 网络安全的学习路线是怎么样的?
  • 【C语言】C语言经典小游戏:贪吃蛇(下)
  • 用 Whisper 打破沉默:AI 语音技术如何重塑无障碍沟通方式?
  • 【iOS】YYModel源码解析
  • Git GitHub Gitee
  • ISBN书号查询接口如何用PHP实现调用?
  • 房屋租赁系统 Java+Vue.js+SpringBoot,包括房屋类型、房屋信息、预约看房、合同信息、房屋报修、房屋评价、房主管理模块
  • Python训练营打卡 Day26
  • JavaScript性能优化:实战技巧提升10倍速度
  • 2025年—Comfy UI 和 Stable Diffusion底层原理
  • docker可视化工具
  • 【头歌实验】Keras机器翻译实战