码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2018-03-01 13:35:57      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:gpo   lag   100%   odi   style   过程   UI   个数   quic   

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)
    

 

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

标签:gpo   lag   100%   odi   style   过程   UI   个数   quic   

原文地址:https://www.cnblogs.com/xiaobingqianrui/p/8487528.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!