冒泡法排序 python
时间: 2023-11-12 07:59:36 浏览: 115
好的,这里是冒泡排序的 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]
return arr
```
这个算法的时间复杂度为 O(n^2),不过它的实现非常简单易懂。
相关问题
冒泡法排序Python
冒泡排序是一种简单的排序算法,它重复地遍历要排序的列表,比较相邻的两个元素,并按照大小顺序交换它们,直到整个列表排序完成。以下是冒泡排序的Python实现:
```python
def bubble_sort(arr):
n = len(arr)
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]
return arr
```
上述代码中,`arr`是待排序的列表。首先,我们使用两个嵌套的循环来遍历列表。外层循环控制遍历的轮数,内层循环用于比较相邻元素并进行交换。如果当前元素大于下一个元素,则交换它们的位置。通过这样的遍历和交换操作,最大的元素会逐渐“冒泡”到列表的末尾。重复执行这个过程,直到整个列表排序完成。
冒泡法排序python
以下是用Python实现冒泡排序的代码:
```python
def bubble_sort(arr):
"""
冒泡排序函数,将输入的数组 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]
return arr
```
以上代码中,我们定义了一个名为`bubble_sort`的函数,该函数接受一个数组作为输入,并返回排序后的数组。在函数内部,我们使用两个嵌套的循环来实现冒泡排序算法。外层循环用于遍历整个数组,内层循环用于处理未排序的部分。如果前一个元素比后一个元素大,则交换它们的位置。最终,我们返回排序后的数组。
阅读全文