首页 > 代码库 > 冒泡排序

冒泡排序

  1. """
  2. 冒泡排序
  3. 把无序的数组按照从小到大的顺序进行排序
  4. 时间复杂度O(n2)
  5. """
  6. # 创建一个不规则数组
  7. import random
  8. arry = []
  9. # 循环20次
  10. for i in range(20):
  11. # 每次生成一个随机数
  12. arry.append(random.randrange(1000))
  13. # 冒泡排序
  14. def bubble_sort1(data):
  15. for i in range(len(data) - 1):
  16. for j in range(len(data) - 1 - i):
  17. if data[j] > data[j + 1]:
  18. data[j], data[j + 1] = data[j + 1], data[j]
  19. # 冒泡排序 如果没有交换那么排序已经完成。
  20. def bubble_sort2(data):
  21. for i in range(len(data) - 1):
  22. exchange = False
  23. for j in range(len(data) - 1 - i):
  24. if data[j] > data[j + 1]:
  25. data[j], data[j + 1] = data[j + 1], data[j]
  26. exchange = True
  27. if not exchange:
  28. break
  29. # 调用冒泡排序
  30. bubble_sort1(arry)
  31. print(arry)
  32. bubble_sort2(arry)
  33. print(arry)

冒泡排序