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

摄影作品网站或app软件工程开发师

摄影作品网站或app,软件工程开发师,wordpress修改首页网址,广州公司注册核名8642 快速排序 时间限制:1000MS 代码长度限制:10KB 提交次数:2105 通过次数:1352 题型: 编程题 语言: G;GCC Description 用函数实现快速排序,并输出每次分区后排序的结果 输入格式 第一行:键盘输入待排序关键的个数n 第二行:输入n个待…

 

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.dtcms.com/wzjs/831667.html

相关文章:

  • 营销式网站有些网站做不了seo
  • 爱站关键词挖掘软件深圳公司网站制作
  • 河南宏业建设管理有限公司网站asp网站防注入代码
  • c 做的网站怎么上传图片网站建设免费加盟代理
  • 网页设计与网站建设教材专门做实习计算机项目的网站平台
  • 如何查看 网站诊断虚拟币交易网站建设
  • 企业电子商务网站建设和一般软件开发文档包括什么内容
  • 织梦做的网站不能用手机访问网上接网站项目
  • 网站都是每年续费的吗天津房地产最新消息
  • 微信分销网站建设比较好免费做免费做人爱视频的网站
  • 公司网站建设概述网页设计免费模板情侣
  • 织梦可以做淘宝客网站吗搭建一个网站的基本流程
  • 中济建设官方网站wordpress 图册业民啊
  • 网站建设项目申请网页介绍模板
  • fwa 网站 欣赏网上举报平台
  • 拨付网站建设费用的报告wordpress图片如何排版
  • 番禺外贸型网站建设网站换关键词
  • 山东做网站网站建设需要几十万
  • 定制型网站建设推广网站建设三网
  • 广州做网站的公司哪家好襄汾县住房和建设局网站
  • 网站建设的简历制作建站系统破解源码
  • 如何提高网站访问速度成都动力无限科技有限公司做网站
  • 有哪些做头像的网站网站设计优缺点
  • 实力网站开发毕业设计做网站好做吗
  • 公司网站的建设哪家好中国建设工程造价网站
  • 西安电子商务网站个人网站 后台管理
  • 环保公司网站模版做网站什么内容吸引人
  • 长沙做网站开发哪里好手机中国官网
  • 犀牛云 做网站网站图片一般多大尺寸
  • 房产交易网上预约平台app优化是什么意思