带你掌握四种 Python 排序算法

开发 后端 算法
在这篇文章中,我们将使用排序算法分类器对我们的数组进行排序,了解它们是如何工作的。为了保障本文的可读性,这里只着重介绍4个排序算法。

 

在编程里,排序是一个重要算法,它可以帮助我们更快、更容易地定位数据。在这篇文章中,我们将使用排序算法分类器对我们的数组进行排序,了解它们是如何工作的。为了保障本文的可读性,这里只着重介绍4个排序算法。

  • 冒泡排序
  • 插入排序.
  • 归并排序.
  • 快速排序

冒泡排序

冒泡排序是一种简单的排序算法,它比较两个相邻对象的顺序,将非预期顺序的相邻对象位置交换。下面是它的工作步骤:

  • 比较第一个和第二个对象,如果第一个大于第二个,将之交换。
  • 将第二个对象和第三个对象进行比较,检查相同条件。以此类推直到比较到数组最后一个数。
  • 重复执行这个过程,这样数组就按照从左到右从小到大排列了。
代码如下
  1. # Python中的冒泡排序 
  2. def bubbleSort(array): 
  3.   
  4.   # 外循环访问数组的每个元素 
  5.   for i in range(len(array)): 
  6.  
  7.     # 内循环将数组元素与外循环迭代元素进行比较 
  8.     for j in range(0, len(array) - i - 1): 
  9.  
  10.       # 比较两个相邻元素 
  11.       if array[j] > array[j + 1]: 
  12.  
  13.         # 如果元素不是预期顺序则交换元素 
  14.         temp = array[j] 
  15.         array[j] = array[j+1
  16.         array[j+1] = temp 
  17. data = [54321
  18.  
  19. bubbleSort(data) 
  20. print('Sorted Array'
  21. print(data) 
  22.  
  23. #output: [12345

插入排序

插入排序也很简单,它分为已经排序和未排序两部分,将未排序部分的元素选中后正确放置在排序部分即可。类似卡牌游戏时我们手里有分类卡。下面是它的工作步骤:

  • 遍历数组查找最低元素的索引并将其与数组的第一个元素交换。
  • 找到数组(不包括第一个元素)中另一个最低的元素,并将其与第二个元素交换 ,然后重复操作,直到数组的最后一个元素。
  • 这样,数组中最低的元素都会移到左边,而最大的元素会在数组的右边,因此数组是有序的。

代码如下:

  1. # Python中的排序算法 
  2. def insertionSort(array): 
  3.     for step in range(1, len(array)): 
  4.         key = array[step] 
  5.         j = step - 1 
  6.         # 将键与其左侧的每个元素进行比较,直到找到小于它的元素 
  7.         while j >= 0 and key < array[j]: 
  8.             array[j + 1] = array[j] 
  9.             j = j - 1 
  10.         # 将键放在比它小的元素之后。 
  11.         array[j + 1] = key 
  12.  
  13. data = [1143212
  14.  
  15. insertionSort(data) 
  16. print("sorted array"
  17. print(data) 
  18.  
  19. #output: [2341112

归并排序

归并排序是基于分治算法原理的最常用的排序算法。我们将数组分为多个部分,然后对他们进行排序,最后将子部分合并为一个排序数组,为了更好的理解,下面是它的工作步骤:

  • 把数组分成小块,直到每一块中没有单独的元素。
  • 比较每一块数组,将最小值放在左侧,最大值放在数组的右侧。
  • 如果觉得很难理解,看看这个动图。

代码如下:

  1. # Python的归并排序 
  2. def mergeSort(array): 
  3.     if len(array) > 1
  4.  
  5.         #  r 是将数组分为两半后的分割点 
  6.         r = len(array)//2 
  7.         L = array[:r] 
  8.         M = array[r:] 
  9.  
  10.         # 通过递归方法对两半进行排序 
  11.         mergeSort(L) 
  12.         mergeSort(M) 
  13.  
  14.         i = j = k = 0 
  15.  
  16.         # 直到我们到达 L 或 M 的任一端,从中选择较大的元素 L 和 M 并将它们放置在 A[p 到 r] 处的正确位置 
  17.         while i < len(L) and j < len(M): 
  18.             if L[i] < M[j]: 
  19.                 array[k] = L[i] 
  20.                 i += 1 
  21.             else
  22.                 array[k] = M[j] 
  23.                 j += 1 
  24.             k += 1 
  25.  
  26.         # 将L或者M里的元素排序好后,将剩余的元素并放入 A[p to r] 
  27.         while i < len(L): 
  28.             array[k] = L[i] 
  29.             i += 1 
  30.             k += 1 
  31.  
  32.         while j < len(M): 
  33.             array[k] = M[j] 
  34.             j += 1 
  35.             k += 1 
  36. array = [861412103
  37.  
  38. mergeSort(array) 
  39. print("Sorted array: "
  40. print(array) 
  41.  
  42. #output: [368101214

快速排序

与归并排序一样,快速排序也是基于分治算法的原理的一种排序算法。它选择一个元素作为枢轴,并围绕枢轴分区数组。下面是它的工作步骤:

  • 选择一个转折点,这可以是随机选择的。这里假设我们选择数组的最后一个元素作为轴心。
  • 将所有小于轴心的项目放在左侧,大于轴心的项目放在数组右侧。
  • 在枢轴的左右两侧重复上面的步骤。
  1. # Python中的快速排序 
  2. # 找到分区位置 
  3. def partition(array, lowest, highest): 
  4.  
  5.   # 这里我们选择最右的元素作为枢轴 
  6.   pivot = array[highest] 
  7.  
  8.   # 为最大的元素设置指针 
  9.   i = lowest - 1 
  10.   # 将每个元素与枢轴元素对比 
  11.   for j in range(lowest, highest): 
  12.     if array[j] <= pivot: 
  13.       i = i + 1 
  14.       # 将 i 处的元素与 j 处的元素交换 
  15.       (array[i], array[j]) = (array[j], array[i]) 
  16.  
  17.   # 将枢轴元素与 i 指定的较大元素交换 
  18.   (array[i + 1], array[highest]) = (array[highest], array[i + 1]) 
  19.  
  20.   # 返回分区完成的位置 
  21.   return i + 1 
  22. def quickSort(array, lowest, highest): 
  23.   if lowest < highest: 
  24.  
  25.      # 找到枢轴元素 
  26.      # 小于枢轴的元素放左边 
  27.      # 大于枢轴的元素放右边 
  28.     pi = partition(array, lowest, highest) 
  29.  
  30.     # 枢轴左侧的递归调用 
  31.     quickSort(array, lowest, pi - 1
  32.  
  33.     # 枢轴右侧的递归调用 
  34.     quickSort(array, pi + 1, highest) 
  35. array = [98321107619
  36.  
  37. size = len(array) 
  38. quickSort(array, 0, size - 1
  39. print('Sorted Array is below'
  40. print(array) 
  41.  
  42. #output [12367891019

 

 

责任编辑:张燕妮 来源: 华为云社区
相关推荐

2023-11-15 07:40:40

2009-09-08 17:20:01

C#排序算法

2015-03-19 15:13:20

PHP基本排序算法代码实现

2023-10-21 21:13:00

索引SQL工具

2021-08-11 20:17:22

推荐算法系统

2024-02-28 09:22:03

限流算法数量

2011-12-30 13:15:53

Java

2024-10-24 08:04:00

2023-07-11 10:24:00

分布式限流算法

2021-10-24 08:37:18

网络监控网络架构网络

2013-03-06 10:07:59

VDI管理

2013-10-17 09:25:52

2010-08-05 13:44:12

Flex布局

2011-11-24 16:34:39

Java

2023-11-27 13:42:00

消息队列RocketMQ

2014-12-25 09:41:15

Android加载方式

2017-07-06 15:40:19

DevOps核心能力

2021-12-22 09:34:01

Golagn配置方式

2019-10-24 07:42:28

Java引用GC

2012-09-11 09:55:26

编程HTML5编程能力
点赞
收藏

51CTO技术栈公众号