python冒泡排序例题
时间: 2023-11-14 20:12:35 浏览: 120
下面是一个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
# 测试
arr = [64, 34, 25, 12, 22, 11, 90]
print(bubble_sort(arr))
```
这个例子中,我们定义了一个名为`bubble_sort`的函数,它接受一个列表作为参数,并返回一个排好序的列表。在函数内部,我们使用了两个嵌套的循环来实现冒泡排序。外层循环控制排序轮数,内层循环控制每轮排序的次数。在每轮排序中,我们比较相邻的两个元素,如果前一个元素比后一个元素大,则交换它们的位置。最终,我们返回排好序的列表。
相关问题
python冒泡字符串排序例题
冒泡排序可以用于对数字列表进行排序,也可以用于对字符串列表进行排序。下面是一个Python冒泡字符串排序的例题:
```
def bubble_sort(str_list):
n = len(str_list)
for i in range(n):
for j in range(0, n-i-1):
if str_list[j] > str_list[j+1]:
str_list[j], str_list[j+1] = str_list[j+1], str_list[j]
return str_list
if __name__ == '__main__':
str_list = ['apple', 'banana', 'orange', 'pear', 'grape']
sorted_list = bubble_sort(str_list)
print(sorted_list)
```
这个例子中,我们定义了一个名为`bubble_sort`的函数,它接受一个字符串列表作为参数,并返回一个排好序的字符串列表。函数中的实现和数字列表的冒泡排序类似,只是比较的对象变成了字符串。在主程序中,我们定义了一个字符串列表,然后调用`bubble_sort`函数对它进行排序,并打印出排好序的列表。
改写程序,在例题11.14的功能基础上,增加两个方法分别实现列表的冒泡法排序和插入法排序,类外分别调用三种排序方法,输出排序结果。
在这个任务中,我们需要创建一个包含列表排序功能的类,并提供三个方法:`bubble_sort()`, `insertion_sort()`, 和一个用于调用这三种排序方法的外部函数。下面是一个Python示例:
```python
class SortingMethods:
def __init__(self, numbers):
self.numbers = numbers
def bubble_sort(self):
n = len(self.numbers)
for i in range(n):
for j in range(0, n-i-1):
if self.numbers[j] > self.numbers[j+1]:
self.numbers[j], self.numbers[j+1] = self.numbers[j+1], self.numbers[j]
return self.numbers
def insertion_sort(self):
for i in range(1, len(self.numbers)):
key = self.numbers[i]
j = i-1
while j >=0 and key < self.numbers[j] :
self.numbers[j+1] = self.numbers[j]
j -= 1
self.numbers[j+1] = key
return self.numbers
@classmethod
def sort_list(cls, unsorted_numbers, sorting_method='bubble'):
"""
外部调用函数,根据指定的排序方法对列表进行排序并返回结果
:param unsorted_numbers: 待排序的列表
:param sorting_method: 排序方法,可选值为 'bubble' (冒泡排序)、'insertion' (插入排序),默认为'bubble'
:return: 排序后的列表
"""
if sorting_method == 'bubble':
sorted_numbers = cls.bubble_sort(unsorted_numbers)
elif sorting_method == 'insertion':
sorted_numbers = cls.insertion_sort(unsorted_numbers)
else:
raise ValueError("Invalid sorting method. Choose either 'bubble' or 'insertion'.")
return sorted_numbers
# 示例使用
numbers = [64, 34, 25, 12, 22, 11, 90]
print(SortingMethods.sort_list(numbers)) # 输出冒泡排序结果
print(SortingMethods.sort_list(numbers, sorting_method='insertion')) # 输出插入排序结果
```
这个程序定义了一个`SortingMethods`类,包含两个排序方法`bubble_sort()`和`insertion_sort()`,还有一个类方法`sort_list()`用于外部调用并选择排序方法。用户可以根据需求调用这两个排序方法对列表进行操作。
阅读全文