Python实现排序算法之快速排序

Python实现快速排序原理首先选取任意一个数据(通常选取数组的第一个数)作为关键数据,然后将所有比它小的放到它前面,所有比它大的放到它后面,这个过程称为一趟快速排序快速排序原理图如下:实现

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

Python实现排序算法:快速排序、冒泡排序、插入排序、选择排序、堆排序、归并排序和希尔排序

Python实现快速排序

原理

  首先选取任意一个数据(通常选取数组的第一个数)作为关键数据,然后将所有比它小的放到它前面,所有比它大的放到它后面,这个过程称为一趟快速排序

  快速排序原理图如下:

Python实现排序算法之快速排序

实现

#coding=utf-8

#python实现快速排序
def quick_sort(li,start,end):
    if start < end:
        flag = li[start]
        print(flag)
        i = start
        j = end
        print ("i=%d;j=%d" %(i,j))
        b = True
        while(i < j):
            while(li[j] >= flag and j > i):
                j = j -1
            li[i] = li[j] 
           
            while(li[i] <= flag and j > i):
                i = i+ 1
            li[j] = li[i]  
            
        li[i] = flag
        print(li)
        quick_sort(li, start, i-1) 
        quick_sort(li, j+1, end) 
        
    
if __name__ == "__main__":
    li = [30,40,60,10,20,50]
    quick_sort(li,0,len(li) - 1)
    

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/120202.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 三次样条插值优缺点_matlab中三次样条差值

    三次样条插值优缺点_matlab中三次样条差值三次样条插值分段线性插值的优点:计算简单、稳定性好、收敛性有保证且易在计算机上实现缺点:它只能保证各小段曲线在连接点的连续性,却无法保证整条曲线的光滑性,这就不能满足某些工程技术的要求。三次Hermit插值优点:有较好的光滑性,缺点:要求节点的一阶导数已知。从20世纪60年代开始,首先由于航空、造船等工程设计的需要而发展起来所谓样条(Spline)插值方法,既保留了分段低次插值多项式的各种优点,又…

    2025年6月24日
    4
  • Java中父类引用指向子类对象好处

    Java中父类引用指向子类对象好处比如对于 HashMap 与 Map 的理解 HashMap 是 Map 接口的常用实现类 Map 是一个接口 是一个键值对集合 建议使用实现接口的方式使用 Map 如 Map String Object parameters newHashMap lt gt 不建议这样 HashMap String Object parameters newHa String Object String Object

    2025年7月9日
    7
  • Razor语法大全(cshtml语法)

    Razor语法大全(cshtml语法)本文页面来源地址:http://www.cnblogs.com/dengxinglin/p/3352078.htmlRazor是基于framewor4以上写的一个开源项目:https://github.com/Antaris/RazorEngine/Razor是包含了模板引擎和动态编译两部分。本部分就简单记录了模板引擎的一些语法,之后用Razor做一个代码生成器,就使用Razor的语法来。Razo

    2022年6月16日
    63
  • MYSQL 数据库引擎

    MYSQL 数据库引擎MySQL 数据库引擎取决于 MySQL 在安装的时候是如何被编译的 要添加一个新的引擎 就必须重新编译 MYSQL 在缺省情况下 MYSQL 支持三个引擎 ISAM MYISAM 和 HEAP 另外两种类型 INNODB 和 BERKLEY BDB 也常常可以使用 如果技术高超 还可以使用 MySQL API 自己做一个引擎 下面介绍几种数据库引擎 nbsp nbsp nbsp ISAM ISAM 是一个定义明确且历经时间考验

    2025年9月13日
    4
  • linux journalctl使用详解[通俗易懂]

    linux journalctl使用详解[通俗易懂]1.概述​journalctl用来查询systemd-journald服务收集到的日志。systemd-journald服务是systemdinit系统提供的收集系统日志的服务。journalctl通常用来查询systemd管理的Unit的日志信息。2.使用方法$manjournalctl$journalctl–helpjournalctl[OPTIONS…][MATCHES…]Querythejournal.Flags:–system

    2022年5月24日
    57
  • Python学习笔记:TypeError: not all arguments converted during string formatting

    Python学习笔记:TypeError: not all arguments converted during string formatting前言在学习python中难免犯下一些幼稚的错误,为了方便后来人的学习,写下此篇文档。问题TypeError:notallargumentsconvertedduringstringformatting举例例如:&amp;gt;&amp;gt;&amp;gt;strs=(1,2,3,4)#创建一个集合&amp;gt;&amp;gt;&amp;gt;strs(

    2022年7月25日
    128

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号