冒泡排序(Bubble Sort)是一种简单的排序算法。它通过重复地交换相邻的元素,将最大的元素逐步“浮”到数组的末尾。以下是冒泡排序的 Python 代码实现:
def bubble_sort(arr):
n = len(arr)
for i in range(n):
swapped = False
for j in range(0, n - i - 1):
if arr[j] > arr[j + 1]:
arr[j], arr[j + 1] = arr[j + 1], arr[j]
swapped = True
# 如果在整个内部循环中都没有交换,则数组已经是排序好的
if not swapped:
break
# 测试示例
arr = [64, 34, 25, 12, 22, 11, 90]
print("原始数组:", arr)
bubble_sort(arr)
print("排序后的数组:", arr)
在上述代码中,bubble_sort
函数接受一个数组arr
作为参数。通过两个嵌套的循环,对数组进行多次遍历。外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果在某一轮遍历中没有发生任何交换,说明数组已经是排序好的,此时可以提前结束循环。
希望这个示例对你有帮助!如果你还有其他关于排序算法或其他主题的问题,随时都可以问我。