关于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
arr = [64, 34, 25, 12, 22, 11, 90]
print(bubble_sort(arr)) # [11, 12, 22, 25, 34, 64, 90]
选择排序
选择排序是一种简单直观的排序算法。它的工作原理是:首先在未排序的数列中找到最小元素,然后将其存放到数列的起始位置;接着,再从剩余未排序的元素中继续寻找最小元素,然后放到已排序序列的末尾。重复进行以上操作,直到全部元素均排序完毕。
示例代码:
def selection_sort(arr):
n = len(arr)
for i in range(n-1):
min_index = i
for j in range(i+1, n):
if arr[min_index] > arr[j]:
min_index = j
arr[i], arr[min_index] = arr[min_index], arr[i]
return arr
arr = [64, 34, 25, 12, 22, 11, 90]
print(selection_sort(arr)) # [11, 12, 22, 25, 34, 64, 90]
插入排序
插入排序是一种简单直观的排序算法。它的基本操作是将一个元素插入到已经排序好的序列中,从而得到一个新的、元素数量加一的有序序列。
示例代码:
def insertion_sort(arr):
for i in range(1, len(arr)):
key = arr[i]
j = i - 1
while j >= 0 and key < arr[j]:
arr[j+1] = arr[j]
j -= 1
arr[j+1] = key
return arr
arr = [64, 34, 25, 12, 22, 11, 90]
print(insertion_sort(arr)) # [11, 12, 22, 25, 34, 64, 90]
以上就是Python排序问题的完整攻略,希望对您有所帮助。
本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:关于Python排序问题(冒泡/选择/插入) - Python技术站