8642 快速排序

SCAU数据结构OJ第六章

文章目录

  • [8642 快速排序](#8642 快速排序)

8642 快速排序

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

代码如下:

c 复制代码
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int M=1e5+5;
int a[M],n;

void Print()
{
    for(int i=1;i<=n;i++)
    {
        cout<<a[i]<<" ";
    }
    cout<<endl;
}
int pos(int l,int r)
{
    a[0]=a[l];
    while(l<r)//跳出循环时经常l == r
    {
        while(l<r && a[r]>=a[0])//先从右边开始,大的放右边不动
        {
            r--;
        }
        a[l]=a[r];//a[l]这里有空位,把后面小的挪过来
        while(l<r && a[l]<=a[0])//这次轮到左边,小的放左边不动
        {
            l++;
        }
        a[r]=a[l];//刚刚右边小的挪走了,有空位
    }
    a[l]=a[0];
    Print();
    return l;//注意return的是左边left的值
}
void FastSort(int l,int r)
{
    if(l<r)
    {
        int mid=pos(l,r);//找到中心点,分出左右子表分别递归再次重复快速排序
        FastSort(l,mid-1);
        FastSort(mid+1,r);
    }
}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
    }
    FastSort(1,n);
    return 0;
}

相关推荐
立志成为大牛的小牛3 分钟前
数据结构——三十九、顺序查找(王道408)
数据结构·学习·程序人生·考研·算法
Shylock_Mister7 分钟前
弱函数:嵌入式回调的最佳实践
c语言·单片机·嵌入式硬件·物联网
2301_807997388 分钟前
代码随想录-day30
数据结构·c++·算法·leetcode
攒钱植发18 分钟前
嵌入式Linux——“大扳手”与“小螺丝”:为什么不该用信号量(Semaphore)去模拟“完成量”(Completion)
linux·服务器·c语言
咔咔咔的25 分钟前
3607. 电网维护
c++
爱代码的小黄人27 分钟前
一般角度的旋转矩阵的推导
线性代数·算法·矩阵
ゞ 正在缓冲99%…44 分钟前
leetcode1771.由子序列构造的最长回文串长度
数据结构·算法·leetcode
多喝开水少熬夜1 小时前
堆相关算法题基础-java实现
java·开发语言·算法
锂享生活1 小时前
论文阅读:铁路车辆跨临界 CO₂ 空调系统模型预测控制(MPC)策略
论文阅读·算法
三品吉他手会点灯1 小时前
STM32F103学习笔记-16-RCC(第3节)-使用HSE配置系统时钟并使用MCO输出监控系统时钟
c语言·笔记·stm32·单片机·嵌入式硬件·学习