当前位置:   article > 正文

数据结构中排序算法_数据结构常用排序算法

数据结构常用排序算法

插入排序

  1. #插入排序:假使左边元素是有序的,在右边元素中选出元素,与左边的元素进行比较,然后放到恰当的有序位置。思想:从右边选出元素放在左边,使得
  2. #左边部分是有序的,右边元素为空,左边元素有序,排序停止
  3. def insert_sort(alist):
  4. n = len(alist)
  5. #从右边的无序序列中取出多少个元素执行这样的过程
  6. for j in range(1,n):
  7. #i代表的是内层循环起始
  8. i = j
  9. #执行从右边的无序序列中取出第一个元素,即i位置的元素,然后将其插入到前面的正确位置中
  10. while i>0:
  11. if alist[i] < alist[i-1]:
  12. alist[i],alist[i-1] = alist[i-1],alist[i]
  13. i -= 1
  14. else:
  15. break
  16. if __name__=="__main__":
  17. li = [6,5,3,1,8,7,2,4]
  18. print(li)
  19. insert_sort(li)
  20. print(li)

选择排序:

  1. #选择排序 最优最坏时间复杂度都为O(n2)不稳定
  2. def select_sort(alist):
  3. n = len(alist)
  4. for j in range(0,n-1):#j:0-(n-2)
  5. min_index = j
  6. for i in range(j+1,n):
  7. if alist[min_index] > alist[i]:
  8. min_index = i
  9. alist[j],alist[min_index] = alist[min_index],alist[j]
  10. if __name__=="__main__":
  11. li = [54,26,93,17,77,31,44,55,20]
  12. print(li)
  13. select_sort(li)
  14. print(li)

冒泡排序:

  1. #bubble_sort
  2. def bubble_sort(alist):
  3. n = len(alist)
  4. for j in range(0,n-1):
  5. for i in range(0,n-1-j):
  6. if alist[i] > alist[i+1]:
  7. alist[i],alist[i+1] = alist[i+1],alist[i]
  8. if __name__=="__main__":
  9. li = [23,45,1,34,65]
  10. print(li)
  11. bubble_sort(li)
  12. print(li)

 

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号