当前位置:   article > 正文

Python——排序方法

Python——排序方法

(1)快速排序

快速排序采用分而治之及递归方法进行实现,将一个较大的序列进行分割。

该方法步骤为:1、选取基准值;2、分割:重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面;3、递归排序子序列:递归地将小于基准值元素的子序列和大于基准值元素的子序列排序。

  1. def quick_sort(arr):
  2. if len(arr) >= 2:
  3. key = arr[len(arr)//2] #选取基准值
  4. right,left = [],[] #定义左右两侧数组
  5. arr.remove(key) #从原数组中移除基准值
  6. for i in arr:
  7. if i < key:
  8. left.append(i)
  9. else:
  10. right.append(i)
  11. return quick_sort(left)+[key]+quick_sort(right)
  12. else:
  13. return arr
  14. arr = [2,3,5,7,1,4,6,15,5,2,7,9,10,15,9,17,12]
  15. print("排序后的的数组为:",quick_sort(arr))

(2)插入排序

工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

  1. def insertionSort(arr):
  2. for i in range(1,len(arr)):
  3. key = arr[i]
  4. j = i-1
  5. while j>=0 and key<arr[j]:
  6. arr[j+1] = arr[j]
  7. j -= 1
  8. arr[j+1] = key
  9. arr = [3,5,2,1,9,7]
  10. insertionSort(arr)
  11. print("排序后的数组:")
  12. for x in range(len(arr)):
  13. print("{}".format(arr[x]))

(3)选择排序 

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下:首先在未排序序列中找到最小元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

  1. def selection_sort(arr):
  2. '''选择排序'''
  3. for i in range(len(arr)):
  4. min_index = i
  5. for j in range(i+1,len(arr)):
  6. if arr[min_index] > arr[j]:
  7. min_index = j
  8. arr[i],arr[min_index] = arr[min_index],arr[i]
  9. return arr
  10. arr = [35,5,8,6,7,56,32,45,88,45]
  11. print("数组排序后:",selection_sort(arr))

(4)冒泡排序

冒泡排序算法的原理如下:

  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。

  2. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。

  3. 针对所有的元素重复以上的步骤,除了最后一个。 

  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

 实列:

对arr = [5,4,6,1,9,8,3,7,10,2,15]

进行冒泡排序:

  1. def bubble_sort(arr):
  2. n = len(arr)
  3. for i in range(n):
  4. for j in range(0,n-i-1):
  5. if arr[j] > arr[j+1]:
  6. arr[j],arr[j+1] = arr[j+1],arr[j]
  7. return arr
  8. arr = [5,4,6,1,9,8,3,7,10,2,15]
  9. print("排序后序列为:",bubble_sort(arr))

 欢迎关注wx公众号:python web小栈,共同探讨学习

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/55321
推荐阅读
相关标签
  

闽ICP备14008679号