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

8642 快速排序

SCAU数据结构OJ第六章

文章目录

  • 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

代码如下:

#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;
}


http://www.kler.cn/a/526329.html

相关文章:

  • rust学习-rust中的保留字
  • 使用 Context API 管理临时状态,避免 Redux/Zustand 的持久化陷阱
  • shiro学习五:使用springboot整合shiro。在前面学习四的基础上,增加shiro的缓存机制,源码讲解:认证缓存、授权缓存。
  • 用 Scoop 优雅管理 Windows 软件:安装、配置与使用全指南
  • Java中的泛型
  • 从替代到覆盖:暴雨信创服务器打开市场新局面
  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.18 逻辑运算引擎:数组条件判断的智能法则
  • Java中的注解与反射:深入理解getAnnotation(Class<T> annotationClass)方法
  • 在 Linux 上安装 Microsoft TrueType 字体:ttf-mscorefonts-installer 指南
  • 数据结构:线性表查找的三种方式
  • 向下调整算法(详解)c++
  • 指针空值——nullptr(C++11)——提升指针安全性的利器
  • Hive:静态分区(分区语法,多级分区,分区的查看修改增加删除)
  • 无公网IP 外网访问 本地部署夫人 hello-algo
  • 【赵渝强老师】K8s中Pod探针的TCPSocketAction
  • 新年手搓--本地化部署DeepSeek-R1,全程实测
  • Pandas进行MongoDB数据库CRUD
  • 题海拾贝:二叉树遍历
  • 【愚公系列】《循序渐进Vue.js 3.x前端开发实践》028-组件Props属性的高级用法
  • 文件上传2
  • vue3第三部分--组件通信
  • 【2024年华为OD机试】 (C卷,100分)- 最大括号深度(Java JS PythonC/C++)
  • python开发,最好的环境是什么
  • ThreadLocal源码解析
  • 5.3.2 软件设计原则
  • [JavaWeb]搜索表单区域