码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 快速排序算法


    快速排序

    先这这组数中随便找一个数作为基准数,

    先从左往右找,找一个大于基准数的数

    在从右往左找,找一个小于基准数的数

    然后交换他们

    举例:

    以i和j遍历数组

    i从前往后

    j从后往前

    j先动

    6、1、2、7、9、3、4、5、10、8

    以6为基准数

    1:7和5交换

    6、1、2、5、9、3、4、7、10、8

    2:9和4交换

    6、1、2、5、4、3、9、7、10、8

    3:i==j i与j相遇 6和3交换 基准数和数组的i位交换

    3、1、2、5、4、6、9、7、10、8

    比6小的数都在6的左边

    比6大的数都在6的右边

    第二轮:

    以3为基准数 处理6的左边

    1:3和2交换

    2、1、3、5、4

    左边以2为基准数处理:

    1、2

    右边以5为基准数处理:

    4、5

    以9为基准数 处理6的左边

    9、7、10、8

    1:8、7、9、10

    左边以8为基准数处理

    7、8

    最后

    1、2、3、4、5、6、7、8、9、10

    #include 
    int a[200],n;
    void quicksort(int left,int right){
        int i,j,t,temp;
        if(left>right)
            return;
        temp=a[left];//temp中存放基准数
        i=left;
        j=right;
        while (i!=j){
            //先从右往左找
            while (a[j]>temp && i<j) j--;
            //再从左往右找
            while (a[i]<=temp && i<j) i++;
            //交换两个数的位置
            if(i<j){
                t=a[i];
                a[i]=a[j];
                a[j]=t;
            }
        }
        a[left]=a[i];
        a[i]=temp;
    
        quicksort(left,i-1);//处理基准数左边的
        quicksort(i+1,right);//处理基准数右边的
    }
    int main(){
        int i,j,t;
        scanf("%d",&n);
        for(i=0;i<n;i++) {
            scanf("%d", &a[i]);
        }
        quicksort(0,n-1);
    
        for(i=0;i<n;i++){
            printf("%d ",a[i]);
        }
            return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40

    image-20220906115207587

    改变12/14行的大于小于号实现从大到小排序

    //先从右往左找
    while (a[j]<temp && i<j) j--;
    //再从左往右找
    while (a[i]>=temp && i<j) i++;
    //交换两个数的位置
    if(i<j){
        t=a[i];
        a[i]=a[j];
        a[j]=t;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    image-20220906115440041

  • 相关阅读:
    rpm打包
    艾美捷双链RNA定量试剂盒作用盒原理分析
    JVM-GC-CMS垃圾回收器
    Prompt设计与大语言模型微调
    Win7系统如何在线进行重装?在线一键重装Win7方法
    隐私计算+区块链原生融合之后平台开放、提升性能,蚂蚁链隐私协作平台FAIR重磅架构升级
    Spring学习笔记——3
    Vue+elementUI二次封装之颜色选择器
    C++项目实战——基于多设计模式下的同步&异步日志系统-④-日志系统框架设计
    前缀和与查分(一维前缀和,二维前缀和(子矩阵的和)一维差分、二维差分(差分矩阵))
  • 原文地址:https://blog.csdn.net/weixin_42403632/article/details/126765649
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号