冒泡排序隔位 Python
时间: 2024-07-19 15:01:16 浏览: 40
冒泡排序是一种简单的排序算法,它的基本思想是通过不断交换相邻元素的位置,使得较大的数逐渐“浮”到序列的顶部,就像气泡一样逐层上升。当提到“隔位冒泡排序”,它是在常规冒泡排序的基础上对数组进行优化的一种策略,通常适用于奇数长度的数组。在这个版本中,算法会每两步只比较和交换一次元素,这样可以减少不必要的比较次数。
以下是Python中隔位冒泡排序的一个示例:
```python
def bubble_sort_odd_positions(arr):
n = len(arr)
# 遍历数组直到最后一个奇数索引
for i in range(0, n, 2):
if i + 1 < n and arr[i] > arr[i+1]:
arr[i], arr[i+1] = arr[i+1], arr[i] # 仅交换奇数位置的元素
# 如果还有剩余的偶数位置未处理
if n % 2 != 0 and arr[n-1] > arr[n-2]:
arr[n-1], arr[n-2] = arr[n-2], arr[n-1]
return arr
# 示例
arr = [64, 34, 25, 12, 22, 11, 90]
sorted_arr = bubble_sort_odd_positions(arr)
print("Sorted array with odd position swapping:", sorted_arr)
相关问题
冒泡排序算法实验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]
# 测试示例
arr = [64, 34, 25, 12, 22, 11, 90]
bubble_sort(arr)
print("排序后的数组:", arr)
```
运行以上代码,将会输出排序后的数组:[11, 12, 22, 25, 34, 64, 90]。
冒泡排序算法的基本思想是通过相邻元素的比较和交换,将较大的元素逐渐“冒泡”到数组的末尾。具体步骤如下:
1. 从数组的第一个元素开始,依次比较相邻的两个元素。
2. 如果前一个元素大于后一个元素,则交换这两个元素的位置。
3. 继续向后比较,直到最后一个元素。
4. 重复以上步骤,每次比较的元素个数减少1,直到所有元素都按照从小到大的顺序排列。
冒泡排序算法实现python
冒泡排序是一种简单的排序算法,其基本思想是通过不断比较相邻的元素并交换位置,将较大的元素逐步“浮”到数组的末尾。下面是用Python实现冒泡排序的方法:
```python
def bubbleSort(arr):
n = len(arr)
for i in range(n - 1):
for j in range(n - 1 - i):
if arr[j] > arr[j + 1]:
arr[j], arr[j + 1] = arr[j + 1], arr[j]
return arr
```
在这个算法中,我们首先获取数组的长度,并使用两个嵌套循环来遍历数组。内部的循环用于比较相邻的元素并交换位置,将较大的元素逐步“浮”到数组的末尾。外部的循环控制遍历的次数,每次遍历都会将当前未排序的最大元素放置到正确的位置。