码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【21天学习挑战赛—经典算法】快速排序


    活动地址:CSDN21天学习挑战赛

    学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。

    CSDN—21天学习挑战赛—【经典算法】

    学习专栏地址

    经典算法_一头小山猪的博客-CSDN博客

    文章

    一文学懂经典算法系列之:快速排序)


    快速排序 QuickSort

    快速排序是对冒泡排序的一种改进,也是一种 交互相邻元素的算法,快速排序所采用的思想是分治的思想。所谓分治,就是指以一个数为基准,将序列中的其他数往它两边“扔”。以从小到大排序为例,比它小的都“扔”到它的左边,比它大的都“扔”到它的右边,然后左右两边再分别重复这个操作,不停地分,直至分到每一个分区的基准数的左边或者右边都只剩一个数为止。

    基本思路

    • 在待排序的数列中,首先要找一个数字作为基准数
    • 一般选择第 1 个数字作为基准数,
    • 然后把这个待排序的数列中小于基准数的元素移动到待排序的数列的左边,
    • 把大于基准数的元素移动到待排序的数列的右边。
    • 此时左右两个分区的元素就是 基准数右边的所有数都大于基准数左边的数;
    • 之后使用同样的思路 从左右两个分区的元素分别按照上面思路,对每个分区找出基准数,然后移动左右数据,
    • 最后分区只剩下一个数时,及完成了排序
    示意图

    时间复杂度

    最坏情况下的时间复杂度和冒泡排序一样,是 O(n2),这种情况并不常见。
    一般情况下快速排序的平均时间复杂度是 O(nlogn),

    • 快速排序被认为是相同数量级的所有排序算法中,平均性能最好的。

    快速排序算法,C语言快速排序算法详解
    快速排序-菜鸟教程

  • 相关阅读:
    day1_QT
    色彩空间介绍
    Consul安装使用
    为什么五千块天价加急费都无法保证交期?
    CSDN每日一练 |『狄杰斯特拉』『选择客栈』『零钱兑换』2023-09-22
    软考架构设计师知识点
    Java if VS switch
    【服务器数据恢复】服务器光纤共享存储互斥失败的数据恢复案例
    CRC校验原理及步骤
    揭秘C语言的心脏:深入探索指针与数组的奥秘
  • 原文地址:https://blog.csdn.net/m0_61486963/article/details/126448384
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号