码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 8行代码实现快速排序,简单易懂图解!


    快速排序是一种常用的排序算法,比选择排序快的多。在之前的我随笔中也写过关于快速排序的算法,也可以看一下和现在的区别python实现快速排序 - Mr-Yang` - 博客园 (cnblogs.com)。

    在看快速排序之前,要先了解一下递归,对于递归我之前的文章中也有提到python递归函数 - Mr-Yang` - 博客园 (cnblogs.com),在这里我补充一个关于递归的一个点:基线条件和递归条件

    一、基线条件和递归条件#

    由于递归函数是自己调用自己,因此编写这样的函数时容易出错,从而导致无限循环。示例如下:

    def countdown(i):
        print(i)
        countdown(i-1)
    

    如果运行上述代码,就会发现一个问题:这个函数运行起来是不会停止,直到到达递归的最大深度。

    正是因为这样,编写递归函数的时候,必须告诉它何时停止递归,所以每个递归函数都有两个部分:基线条件(base case)和递归条件(recursive case)。递归条件指定的是函数调用自己,而基线条件则指的是不再调用自己,从而避免循环。例如给 countdown 添加基线条件。

    def countdown(i):
        print(i)
       	if i <= 1:	#<----------基线条件
            return
        else:	#<--------------递归条件
            countdown(i-1)
    

    这样就按照预期那样执行,不会无限循环下去如图所示

    递归函数

    二、快速排序#

    因为对于排序来说,最简单的就是一个空列表,或者只包含一个元素的列表,所以可以将基线条件设置为空或只包含一个元素,在这种情况下,只需要返回原列表。

    def quicksort(alist):
        if len(alist) < 2:
            return alist
    

    思路如下图所示:

    快速排序思路

    代码如下:

    def quicksort(alist):
        if len(alist) < 2:
            return alist	# 基线条件为空或只包含一个元素的列表是有序的。
        else:
            pivot = alist[0]	# 选择基准值
            less = [i for i in alist[1:] if i <= pivot]	# 由小于基准值的元素组成
            biggish = [i for i in alist[1:] if i > pivot]	# 由大于基准值的元素组成
            return quicksort(less) + [pivot] + quicksort(biggish)
    
  • 相关阅读:
    辅助驾驶功能开发-功能规范篇(24)-3-影子模式功能触发规范
    Java 变量初始化的两种方式和优缺点比较
    看看redis的数据结构你都知道哪些
    微信小程序开发04 性能优化:借助微信开发者工具提升小程序性能
    Shell 批量创建文件夹
    【干货技巧】最新 Java 后端面试系列干货,都在这了!
    【C语言】分支结构
    小柏实战学习Liunx(图文教程二十二)
    vue重修之Vuex【下部】
    Tensorflow使用TFRecords和tf.Example
  • 原文地址:https://www.cnblogs.com/XiaoYang-sir/p/16425804.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号