数据结构与算法(python版)(九)——选择排序

数据结构与算法(python版)(九)

1、选择排序(select sort)

首先在未排序序列中找到最小元素,存放到排序序列的起始位置,再从剩余未排序元素中继续寻找最小元素,然后放到已排序序列的末尾,以此往复,直到所有元素均排序完毕
选择排序的主要优点与数据移动有关,如果某个元素位于正确的最终位置上,则不会被移动,选择排序每交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的列表进行排序总共进行至多n-1次交换,在所有完全依靠交换移动元素的排序方法中,选择排序是非常好的方法
在这里插入图片描述

  • 假设第一个元素时最小值,记下第一个元素的下标为min
  • 将第一个元素与第二个元素进行比较,若第二个元素比第一个元素小,则更新记录的下标min
  • 从头到尾遍历一遍后,得到当前列表最小值的下标,交换到列表的第一位
  • 每一次遍历剩余元素的列表,得到当前最小值元素的下标,将元素交换到列表前

2、选择排序的实现

#选择排序的内层循环代码
#找到当前要排序列表的最小值下标后,与第一个元素进行交换
'''
min_index = 0
for i in range(1, n):  #要排序列表的第一个元素(index = 0)与第二个元素(index = 1)开始比较到最后一个元素(index = n-1)
    if alist[min_index] > alist[i]:
        min_index = i
        #这一层遍历后得到了当前要排序列表的最小值下标
        #将最小值交换到首位
        alist[0], alist[min_index] = alist[min_index], alist[0]
'''
# i:内层循环中与min_index比较的元素下标
#j:外层循环,随已被排序元素增加而增加

def select_sort(alist):
    #选择排序
    n = len(alist)
    for j in range(n-1):  # 外层循环,直到倒数第二个元素
        min_index = j     #min_index的位置随外循环变化,j : 0 ~ n-2
        for i in range(j+1, n):    # i是被比较元素的下标,从j+1开始
            if alist[min_index] > alist[i]:
                min_index = i
        alist[j], alist[min_index] = alist[min_index], alist[j]
    
if __name__ == '__main__':
    li = [54, 26, 93, 17, 77, 31, 44, 55, 20]
    print(li)
    select_sort(li)
    print(li)
    

3、时间复杂度

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

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

不稳定

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值