冒泡排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了冒泡排序相关的知识,希望对你有一定的参考价值。

  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)

以上是关于冒泡排序的主要内容,如果未能解决你的问题,请参考以下文章

java冒泡排序法代码

python代码实现鸡尾酒排序(双向冒泡排序)

冒泡排序python代码

视频+图文+动画详解冒泡排序

交换排序(冒泡排序快速排序的算法思想及代码实现)

C语言冒泡排序。