python 编写函数,列表选择法排序。
时间: 2024-05-13 12:13:52 浏览: 11
当我们需要对一个列表进行排序时,可以使用选择排序法。选择排序法的基本思想是:每次从未排序的部分选出最小(或最大)的元素,放到已排序的部分的末尾。
下面是一个 Python 函数,实现了选择排序法:
```python
def selection_sort(lst):
n = len(lst)
for i in range(n - 1):
min_index = i
for j in range(i + 1, n):
if lst[j] < lst[min_index]:
min_index = j
lst[i], lst[min_index] = lst[min_index], lst[i]
return lst
```
使用方法:
```python
lst = [5, 3, 8, 6, 4]
sorted_lst = selection_sort(lst)
print(sorted_lst) # 输出 [3, 4, 5, 6, 8]
```
这个函数的时间复杂度为 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
```
这个函数使用了嵌套的环来比较相邻的元素并进行交换,将较大的元素逐步“冒泡”到最后。在外层循环中,每次都会固定一个最大的元素到正确的位置,直到所有元素都被排列好为止。最后,函数返回已排序的数组。
你可以将一个需要排序的列表作为参数传递给 `bubble_sort` 函数,并获得排序好的结果。例如:
```python
my_list = [18, 5, 3, 10, 7]
sorted_list = bubble_sort(my_list)
print(sorted_list)
```
该代码将输出 `[3, 5, 7, 10, 18]`,表示列表已经按照升序进行了排序。希望这对你有帮助!如果还有其他问题,请随时提问。
冒泡法编写函数列表排序Python
以下是使用冒泡排序法编写的Python代码来对函数列表进行排序:
```python
def bubble_sort(functions):
n = len(functions)
# 遍历所有数组元素
for i in range(n):
# 最后i个元素已经排好,不需要再比较
for j in range(0, n-i-1):
# 如果当前元素大于下一个元素,则交换它们的位置
if functions[j] > functions[j+1]:
functions[j], functions[j+1] = functions[j+1], functions[j]
return functions
# 示例
functions = ['print', 'input', 'len', 'range', 'sum']
print(bubble_sort(functions))
# 输出: ['input', 'len', 'print', 'range', 'sum']
```
在上面的代码中,我们定义了一个名为 `bubble_sort` 的函数,它接受一个函数列表作为参数,并使用冒泡排序法对其进行排序。在主程序中,我们定义了一个函数列表,然后调用 `bubble_sort` 来对其进行排序。最后,我们打印出排好序的函数列表。