python算法(二):选择排序

python 算法(二):选择排序

算法分析

仍然是排序算法,并且与冒泡排序堪称双生兄弟.逻辑基本一样,唯一不同的时,冒泡排序实行,见一个爱一个的渣男逻辑,而选择排序是一个谋定后而动的狠角.
示例:
3 2 5 7 1 4 6
按从小到大排序
从第一个数开始
3 记录索引 0
3 > 2,记录索引 1
2 < 5 不操作
2 < 7 不操作
2 >1 记录索引 4
1 <4 不操作
1<6 不操作
最终索引记录为4
交换第一个数与第五个(索引是4)的两个数的位置
第一轮:
1 2 5 7 3 4 6
以此继续第二个数
2 索引记录 1
2<5 不操作
2 < 7 不操作
2 < 3 不操作
2 < 4 不操作
2 < 6 不操作
自己与自己交换(可以增加一个判断要不要交换)
第二轮:
1 2 5 7 3 4 6

代码:


# coding = "utf-8"

# 作者: 爱编程的章老师
# 时间: 2021年1月30日

"""[选择排序]"""
    
def selection_sort(num_list:list):
    for i in range(len(num_list)-1):
        temp = i
        for j in range(i + 1, len(num_list)):
            if num_list[temp] > num_list[j]:
                temp = j
        num_list[i], num_list[temp] = num_list[temp], num_list[i]

num_list_demo = [3, 2, 5, 7, 1, 4, 6]

print(num_list_demo)
selection_sort(num_list_demo)
print(num_list_demo)

运行结果

在这里插入图片描述

后记

在排序这个问题上,前辈们一直在努力,寻找更加高效,高加优秀的排序算法.
作为算法的入门案例.
即要学会相应的算法,也要努力去思考前辈们思考的逻辑.学会用解决问题的逻辑去思考问题.这才是我们学习算法的最根本目的,而不仅仅是针对某一个算法

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱编程的章老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值