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

2019.9.24-快速排序实现(完整代码)

时间:2019-09-24 21:16:33      阅读:136      评论:0      收藏:0      [点我收藏+]

标签:first   odi   代码   左移   info   name   quick   bsp   lis   

# coding:utf-8


def quick_sort(alist, first, last):
"""快速排序"""
if first >= last:
return
mid_value = alist[first]
low = first
high = last
while low < high:
# high 左移
while low < high and alist[high] >= mid_value:
high -= 1
alist[low] = alist[high]

while low < high and alist[low] < mid_value:
low += 1
alist[high] = alist[low]
#從循環退出時, low==high
alist[low] = mid_value

# 對low左邊的列表執行快速排序
quick_sort(alist, first, low-1)

# 對low右邊的列表排序
quick_sort(alist, low+1, last)


if __name__ == "__main__":
li = [54, 26, 93, 17, 77, 31, 44, 55, 20]
print(li)
quick_sort(li, 0, len(li)-1)
print(li)

技术图片

 

 技术图片

 

 

 

 

 

执行结果

技术图片

 

2019.9.24-快速排序实现(完整代码)

标签:first   odi   代码   左移   info   name   quick   bsp   lis   

原文地址:https://www.cnblogs.com/lishuide/p/11580878.html

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