Python写冒泡排序的代码
时间: 2023-02-21 14:13:03 浏览: 25
答:下面是Python写的冒泡排序的代码:
def bubbleSort(nums):
n = len(nums)
# 遍历所有数组元素
for i in range(n):
# Last i elements are already in place
for j in range(0, n-i-1):
if nums[j] > nums[j+1] :
nums[j], nums[j+1] = nums[j+1], nums[j]
相关问题
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()`函数,该函数接受一个数组作为参数,并对其进行冒泡排序。冒泡排序算法的核心思想是比较相邻的元素并交换它们,这样每次遍历都可以将未排序部分中的最大元素“冒泡”到已排序部分的末尾。在每一次遍历中,我们都将数组中的元素按照递增的顺序排序。
python简单冒泡排序代码
冒泡排序是一种简单常用的排序算法,也是入门级排序算法之一。Python中实现冒泡排序方法非常简单,下面是一个Python简单冒泡排序的代码示例:
```
def bubble_sort(nums):
n = len(nums)
for i in range(n):
# 一轮排序会将最大的数“冒泡”到最上面,故最后i个数不需要再排序
for j in range(n-1-i):
if nums[j] > nums[j+1]:
nums[j], nums[j+1] = nums[j+1], nums[j]
if __name__ == '__main__':
nums = [5, 3, 2, 4, 1]
bubble_sort(nums)
print(nums)
```
通过这段代码可见,先将待排序序列的长度存储下来,然后利用两层循环实现冒泡排序。内层循环每一轮会将当前未排序区间最大的数“冒泡”到最上面,所以可以不用考虑已排序的数。外层循环则控制排序轮数。排序过程中,如果发现前一个数比后一个数大,交换这两个数的位置。最后当排序完成后,将排好序的序列输出。
阅读全文