冒泡排序注意三点:
- 第一层循环可不用循环所有元素。
- 两层循环变量相关联。
- 第二层循环,最终必须循环集合内所有元素。
示例代码一:
- 第一层循环,只循环n-1个元素。
- 当第一层循环变量为n-1时,第二层循环所有元素。
s = [3, 4, 1, 6, 2, 9, 7, 0, 8, 5] # bubble_sort for i in range(0, len(s) - 1): for j in range(i + 1, 0, -1): if s[j] < s[j - 1]: s[j], s[j - 1] = s[j - 1], s[j] for m in range(0, len(s)): print(s[m])
示例代码二:
- 第一层循环所有元素。
- 第二层也循环所有元素。
1 s = [3, 4, 1, 6, 2, 9, 7, 0, 8, 5] 2 3 4 for i in range(0, len(s)): 5 for j in range(i, 0, -1): 6 if s[j] < s[j - 1]: 7 s[j], s[j - 1] = s[j - 1], s[j] 8 9 for m in range(0, len(s)): 10 print(s[m])