当前位置:   article > 正文

数据结构与算法(Python)——Lesson4_for i in range(n-1)

for i in range(n-1)

冒泡排序

  1. def bubble_sort(alist):
  2. for j in range(len(alist)-1,0,-1):
  3. # j表示每次遍历需要比较的次数,是逐渐减小的
  4. for i in range(j):
  5. if alist[i] > alist[i+1]:
  6. alist[i], alist[i+1] = alist[i+1], alist[i]
  7. li = [54,26,93,17,77,31,44,55,20]
  8. bubble_sort(li)
  9. print(li)
'
运行

时间复杂度

  • 最优时间复杂度:O(n) (表示遍历一次发现没有任何可以交换的元素,排序结束。)
  • 最坏时间复杂度:O(n2)
  • 稳定性:稳定

稳定表示出现相同数据时,两个数据原始位置不会发生改变。

如:当(32,1)和(32,2)出现在同一序列时,执行冒泡排序之后(32,1)仍在(32,2)的前面,两者顺序不会发生改变。

选择排序

  1. def selection_sort(alist):
  2. n = len(alist)
  3. # 需要进行n-1次选择操作
  4. for i in range(n-1):
  5. # 记录最小位置
  6. min_index = i
  7. # 从i+1位置到末尾选择出最小数据
  8. for j in range(i+1, n):
  9. if alist[j] < alist[min_index]:
  10. min_index = j
  11. # 如果选择出的数据不在正确位置,进行交换
  12. if min_index != i:
  13. alist[i], alist[min_index] = alist[min_index], alist[i]
  14. alist = [54,226,93,17,77,31,44,55,20]
  15. selection_sort(alist)
  16. print(alist)
'
运行

时间复杂度

  • 最优时间复杂度:O(n2)
  • 最坏时间复杂度:O(n2)
  • 稳定性:不稳定(考虑升序每次选择最大的情况)

插入排序

  1. def insert_sort(alist):
  2. # 从第二个位置,即下标为1的元素开始向前插入
  3. for i in range(1, len(alist)):
  4. # 从第i个元素开始向前比较,如果小于前一个元素,交换位置
  5. for j in range(i, 0, -1):
  6. if alist[j] < alist[j-1]:
  7. alist[j], alist[j-1] = alist[j-1], alist[j]
  8. alist = [54,26,93,17,77,31,44,55,20]
  9. insert_sort(alist)
  10. print(alist)
'
运行

 另一种写法:用while——break循环

  1. def insert_sort(alist):
  2. # 从第二个位置,即下标为1的元素开始向前插入
  3. for j in range(1, len(alist)):
  4. # 从第i个元素开始向前比较,如果小于前一个元素,交换位置
  5. i = j
  6. while i > 0:
  7. if alist[i] < alist[i-1]:
  8. alist[i], alist[i-1] = alist[i-1], alist[i]
  9. else:
  10. break
  11. alist = [54,26,93,17,77,31,44,55,20]
  12. insert_sort(alist)
  13. print(alist)
'
运行

时间复杂度

  • 最优时间复杂度:O(n) (升序排列,序列已经处于升序状态)
  • 最坏时间复杂度:O(n2)
  • 稳定性:稳定
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/煮酒与君饮/article/detail/944145
推荐阅读
相关标签
  

闽ICP备14008679号