python 冒泡法 探探探

冒泡排序是一种简单的排序算法,它通过重复交换相邻元素来工作。算法每一次遍历数组都会比较相邻两个元素的大小,如果前一个元素比后一个元素大,则交换这两个元素的位置。这样一次遍历之后,最大的元素就会被移动到数组的最后面。重复进行这样的操作,直到整个数组都被排序。

下面是使用 Python 实现冒泡排序的代码:

python
def bubble_sort(arr):
n = len(arr)
# 遍历整个数组
for i in range(n):
# 每次遍历将最大的元素移动到最后面
for j in range(0, n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]

测试代码

arr = [64, 34, 25, 12, 22, 11, 90]
bubble_sort(arr)
print(“排序后的数组:”)
for i in range(len(arr)):
print(“%d” %arr[i])
输出结果为:

排序后的数组:
11
12
22
25
34
64
90
在这个示例中,我们首先定义了一个名为 bubble_sort 的函数,它接受一个数组作为输入参数。函数的主体部分包含两重循环,第一重循环用于遍历整个数组,第二重循环用于将最大的元素移动到最后面。在第二重循环中,我们使用了一个 if 语句来比较相邻两个元素的大小,如果前一个元素比后一个元素大,则交换这两个元素的位置。最后,我们使用一个 for 循环来输出排序后的数组。

冒泡排序的时间复杂度为 O(n^2)O(n
​2
​​ ),因此在处理大规模数据时可能会比较慢。但是由于它的实现非常简单,所以在处理小规模数据时可能会比其他复杂的排序算法更快。

接下来,我们将更详细地讨论冒泡排序的原理、实现和优化方法。

原理
冒泡排序是一种基于比较的排序算法,它的原理非常简单:每次遍历数组,比较相邻两个元素的大小,如果前一个元素比后一个元素大,则交换这两个元素的位置。这样一次遍历之后,最大的元素就会被移动到数组的最后面。重复进行这样的操作,直到整个数组都被排序。

为了更好地理解冒泡排序的原理,我们可以看一下下面这张图:

冒泡排序原理

图中展示了一个长度为 6 的数组,我们要对它进行从小到大的排序。首先,我们将数组中的第一个元素和第二个元素进行比较,发现第一个元素比第二个元素大,因此交换它们的位置。这样一来,第一个元素就变成了 2,第二个元素就变成了 1。接下来,我们将数组中的第二个元素和第三个元素进行比较,发现第二个元素比第三个元素大,因此交换它们的位置。这样一来,第二个元素就变成了 3,第三个元素就变成了 1。依此类推,直到整个数组都被排序。

冒泡排序的时间复杂度为 O(n^2)O(n
​2
​​ ),其中 nn 是数组的长度。这是因为,在最坏情况下,每个元素都需要和其他元素进行比较,因此总共需要进行 n(n-1)/2n(n−1)/2 次比较和交换操作。虽然冒泡排序的时间复杂度比其他高效的排序算法要高,但是它的实现非常简单,因此在处理小规模数据时可能会比其他复杂的排序算法更快。

实现
下面是使用 Python 实现冒泡排序的代码:

python
def bubble_sort(arr):
n = len(arr)
# 遍历整个数组
for i in range(n):
# 每次遍历将最大的元素移动到最后面
for j in range(0, n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
在这个示例中,我们首先定义了一个名为 bubble_sort 的函数,它接受一个数组作为输入参数。函数的主体部分包含两重循环,第一重循环用于遍历整个数组,第二重循环用于将最大的元素移动到最后面。在第二重循环中,我们使用了一个 if 语句来比较相邻两个元素的大小,如果前一个元素比后一个元素大,则交换这两个元素的位置。

在 Python 中,我们可以使用 len 函数来获取数组的长度,使用 range 函数来生成一个指定范围的整数序列。在第二重循环中,我们使用了 range 函数来生成一个从 0 到 n-i-2 的整数序列,因为我们只需要遍历到倒数第二个元素,最后一个元素已经在上一次遍历中被移动到了正确的位置。

为了测试我们的冒泡排序实现是否正确,我们可以使用下面的代码:

python
arr = [64, 34, 25, 12, 22, 11, 90]
bubble_sort(arr)
print(“排序后的数组:”)
for i in range(len(arr)):
print(“%d” %arr[i])
这段代码将创建一个长度为 7 的数组,然后调用我们的 bubble_sort 函数来对它进行排序。最后,我们使用一个 for 循环来输出排序后的数组。

优化
虽然冒泡排序的实现非常简单,但是它的时间复杂度为 O(n^2)O(n
​2
​​ ),因此在处理大规模数据时可能会比较慢。为了提高冒泡排序的效率,我们可以尝试使用一些优化方法。

优化一:提前结束
在每一次遍历数组时,如果发现没有任何元素需要交换位置,那么就可以提前结束遍历。这是因为,如果在一次遍历中没有进行任何交换操作,那么说明整个数组已经被排好序了,不需要再进行后续的遍历。

下面是使用 Python 实现这种优化方法的代码:

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
在这个示例中,我们在第二重循环之前添加了一个 swapped 标志,它的初始值为 False。在每次进行交换操作之后,我们将 swapped 标志设置为 True。在第二重循环结束之后,我们检查 swapped 标志的值,如果它仍然为 False,那么就说明整个数组已经被排好序了,可以提前结束遍历。

优化二:双向冒泡排序
双向冒泡排序是一种改进的冒泡排序算法,它可以同时从数组的两端进行遍历,从而提高排序的效率。具体来说,双向冒泡排序算法会在每一次遍历时同时从数组的第一个元素和最后一个元素开始遍历,然后分别将最小的元素和最大的元素移动到数组的两端。然后,它会缩小数组的范围,从第二个元素和倒数第二个元素开始遍历,然后再次将最小的元素和最大的元素移动到数组的两端。重复进行这样的操作,直到整个数组都被排序。

下面是使用 Python 实现双向冒泡排序的代码:

python
def bubble_sort(arr):
n = len(arr)
left = 0
right = n - 1
# 遍历整个数组
while left < right:
# 从左到右遍历,将最大的元素移动到最后面
for i in range(left, right):
if arr[i] > arr[i+1]:
arr[i], arr[i+1] = arr[i+1], arr[i]
right -= 1
# 从右到左遍历,将最小的元素移动到最前面
for i in range(right, left, -1):
if arr[i] < arr[i-1]:
arr[i], arr[i-1] = arr[i-1], arr[i]
left += 1
在这个示例中,我们首先定义了一个名为 bubble_sort 的函数,它接受一个数组作为输入参数。函数的主体部分包含一个 while 循环,它会在每一次遍历之后缩小数组的范围。在 while 循环中,我们首先从左到右遍历数组,将最大的元素移动到最后面。然后,我们将 right 指针向左移动一位,从右到左遍历数组,将最小的元素移动到最前面。最后,我们将 left 指针向右移动一位,缩小数组的范围。重复进行这样的操作,直到整个数组都被排序。

双向冒泡排序的时间复杂度为 O(n^2)O(n
​2
​​ ),但是它的实现比普通的冒泡排序要更加高效,因为它可以同时从数组的两端进行遍历,从而提高排序的效率。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

实相无相

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值