《算法图解》第二章学习心得(二)

选择排序算法python3代码:

def findSmallest(arr):
    smallest=arr[0]#存储最小的值
    smallest_index=0#存储最小元素的索引
    for i in range(1,len(arr)):
        if arr[i]<smallest:
            smallest_index=i
    return smallest_index

def selectionSort(arr):
    newArr=[]
    for i in range(len(arr)):
        smallest=findSmallest(arr)
        newArr.append(arr.pop(smallest))#找出数组中最小的元素, 并将其加入到新数组中
    return newArr

测试:

print(selectionSort([5, 3, 6, 2, 10]))
输出:
[2, 3, 5, 6, 10]

本章小结:

  1. 需要存储多个元素时, 可使用数组或链表。
  2. 数组的元素都在一起。
  3. 链表的元素是分开的, 其中每个元素都存储了下一个元素的地址。
  4. 数组的读取速度很快。
  5. 链表的插入和删除速度很快。
  6. 在同一个数组中, 所有元素的类型都必须相同(都为intdouble等) 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

gxls2024

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

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

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

打赏作者

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

抵扣说明:

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

余额充值