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

选择排序算法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等) 。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值