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

Posted liuzhiqaingxyz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python数据结构与算法第九天选择排序相关的知识,希望对你有一定的参考价值。

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数据结构与算法第九天选择排序的主要内容,如果未能解决你的问题,请参考以下文章

每日一算法|计数排序---第九天

C++/Python冒泡排序与选择排序算法详解

Python数据结构与算法(13)---选择排序

Python数据结构与算法(13)---选择排序

python设计模式第九天策略模式

python 数据结构与算法之排序(冒泡,选择,插入)