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

python数据结构与算法第九天【选择排序】

时间:2018-08-12 12:03:42      阅读:140      评论:0      收藏:0      [点我收藏+]

标签:选择排序   com   src   复杂度   pre   选择   style   index   最大的   

1.选择排序的原理

技术分享图片

2.代码实现

def selection_sort(alist):
    n = len(alist)
    # 需要进行n-1次选择操作
    for i in range(n-1):
        # 记录最小位置
        min_index = i
        # 从i+1位置到末尾选择出最小数据
        for j in range(i+1, n):
            if alist[j] < alist[min_index]:
                min_index = j
        # 如果选择出的数据不在正确位置,进行交换
        if min_index != i:
            alist[i], alist[min_index] = alist[min_index], alist[i]

alist = [54,226,93,17,77,31,44,55,20]
selection_sort(alist)
print(alist)

3.时间复杂度

最优时间复杂度:O(n2)

最坏时间复杂度:O(n2)

稳定性:不稳定(考虑升序每次选择最大的情况)

python数据结构与算法第九天【选择排序】

标签:选择排序   com   src   复杂度   pre   选择   style   index   最大的   

原文地址:https://www.cnblogs.com/liuzhiqaingxyz/p/9461947.html

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