编写一个python程序,实现冒泡排序
时间: 2023-04-23 16:00:21 浏览: 59
以下是一个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])
```
该程序首先定义了一个名为`bubble_sort`的函数,该函数接受一个列表作为参数。然后,程序使用两个嵌套的`for`循环来遍历列表中的元素,并比较相邻的元素。如果前面的元素大于后面的元素,则交换它们的位置。这个过程会重复进行,直到列表中的所有元素都被排序。最后,程序打印出排序后的列表。
相关问题
编写一个程序实现冒泡排序算法
好的,以下是 Python 语言实现冒泡排序算法的代码:
```python
def bubble_sort(arr):
n = len(arr)
# 遍历数组,进行 n-1 轮冒泡
for i in range(n - 1):
# 每轮冒泡将最大的数放到最后
for j in range(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])
```
代码的思路是,首先遍历数组进行 n-1 轮冒泡,每轮冒泡将最大的数放到最后,然后在下一轮冒泡中就不再考虑已经排好序的数了。具体实现是通过两个 for 循环实现的,其中外层循环控制轮数,内层循环控制每轮中的比较和交换操作。最后输出排序后的数组即可。
Python编写程序写一个冒泡排序
可以参考如下代码实现冒泡排序:
```python
def bubble_sort(arr):
n = len(arr)
# 遍历所有数组元素
for i in range(n):
# 最后 i 个元素已经排好,不需要再比较
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
```