冒泡排序代码python
时间: 2023-09-22 15:06:16 浏览: 119
### 回答1:
冒泡排序的python代码如下:
def bubbleSort(arr):
n = len(arr)
# Traverse through all array elements
for i in range(n):
# Last i elements are already in place
for j in range(0, n-i-1):
# traverse the array from 0 to n-i-1
# Swap if the element found is greater
# than the next element
if arr[j] > arr[j+1] :
arr[j], arr[j+1] = arr[j+1], arr[j]
### 回答2:
冒泡排序是一种简单的排序算法,它重复地从列表中的相邻元素中比较两个元素的大小并交换位置,直到整个列表排序完成。
下面是用Python编写的冒泡排序代码:
```python
def bubble_sort(arr):
n = len(arr)
for i in range(n-1):
# 设定一个标志,若某轮没有发生元素交换,则说明列表已经有序,可提前退出循环
flag = False
for j in range(n-i-1):
if arr[j] > arr[j+1]:
# 交换两个元素的位置
arr[j], arr[j+1] = arr[j+1], arr[j]
flag = True
if not flag:
break
return arr
```
在这个代码中,我们首先定义了一个函数`bubble_sort`,该函数接受一个列表作为参数。
算法的核心部分是两个嵌套的`for`循环。外层循环遍历了列表中的每个元素,共进行了`n-1`轮比较。内层循环用于比较列表中相邻的两个元素,如果它们的顺序不符合要求,则交换它们的位置。
在内层循环的每一轮中,我们设定了一个标志`flag`,用于记录该轮是否发生了元素交换。如果没有交换,说明列表已经有序,我们可以提前退出循环,避免不必要的比较。
最后,我们返回排序后的列表。
希望这个回答对您有帮助!
### 回答3:
冒泡排序是一种简单但效率较低的排序算法,其原理是通过比较相邻的元素并交换他们的位置,将较大的元素逐渐“冒泡”到最后面。下面是冒泡排序的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])
```
在这段代码中,`bubble_sort`函数接受一个数组作为输入参数,然后使用两层循环,外层循环控制冒泡的次数,内层循环用于比较相邻元素并交换位置。如果前一个元素大于后一个元素,则交换它们的位置。重复这个过程直到数组完全排序。
在上面的测试代码中,我们使用`bubble_sort`函数对一个包含整数的数组进行排序。最后,我们打印出排序后的数组。
需要注意的是,冒泡排序的时间复杂度为O(n^2),因此对于大规模数据集时效率较低,但对于小规模数据集或数据集已经基本有序的情况下,冒泡排序仍然是一个简单实用的排序算法。
阅读全文