如何深度理解排序算法(一)

简介: 对于算法的理解、可以看成解决问题的过程和方式、无论算法是好还是坏,它都是一个独立的个体。在众多算法中,排序算法是经常被用到,或者在以往的生活或者面试当中会被提到的,所以理解和学会排序算法是非常重要的。

对于算法的理解、可以看成解决问题的过程和方式、无论算法是好还是坏,它都是一个独立的个体。在众多算法中,排序算法是经常被用到,或者在以往的生活或者面试当中会被提到的,所以理解和学会排序算法是非常重要的。

image.png

还记得上小学的时候,老师会叫我们按照身高高低,进行低的在前高的在后的原则、进行排队放学回家。那么大家思考下,如何排队是最有效的呢?!

image.png

首先,我们第一个想到的是什么呢?从第一个学生开始以此与相邻的学生进行比较,如果右边学生的身高大于左边的,就把右边的学生和左边的学生的位置调换,反之不交换位置。他的思维大概是这样的。

image.png

根据这个gif动画可以看出、它就像一个泡泡一样慢慢的往上升,这种算法就是冒泡排序,为了便于理解和加深记忆,我们以python代码来模拟下这种思路:

# 冒泡排序
def bubbleSort(sort):
    n = len(sort)
    for i in range(n):  # 获取所有的数组元素
        for j in range(0, n - i - 1):  # 最后 i 个元素已经到位
            if sort[j] > sort[j + 1]:
                sort[j], sort[j + 1] = sort[j + 1], sort[j]

    return sort

if __name__ == "__main__":
    sort = [5, 9, 3, 1, 2, 8, 4, 7, 6]
    print(bubbleSort(sort))

根据以上描述可以看出,每次循环就会以相邻的数组进行比较、如果当前数组大于相邻的数组,就把两个的位置进行交换然后返回结果。

那如果老师不喜欢这种方法呢?那我们可不可以这样做呢?重复从人员当前查找身高最小的,然后行交换位置。

image.png

根据这个规律可以看出,每次选择最小值、进行判断然后交换位置,这种算法就是选择排序。

# 选择排序
def selectSort(sort):
    n = len(sort)
    for i in range(n):
        min_num = i
        for j in range(i + 1, n):
            if sort[min_num] > sort[j]:
                min_num = j
        sort[i], sort[min_num] = sort[min_num], sort[i]

    return sort

if __name__ == "__main__":
    sort = [5, 9, 3, 1, 2, 8, 4, 7, 6]
    print(selectSort(sort))

大家可以思考下,可不可以这样做,就像我们玩扑克牌一样,从排好序的牌里去和我们抓的牌进行相比较呢?这样是不是更好呢?这种方式其实就是今天我们所说的插入排序的方法。

image.png

根据这个描述可以看出,每次从选择区去和待选择的区域进行比较、然后交换位置。

# 插入排序
def insertSort(sort):
   """
   插入排序
   :param arr: 待排序List
   :return: 插入排序是就地排序(in-place)
   """
   length = len(sort)
   if length <= 1:
       return
   for i in range(1, length):
       key = sort[i]

       j = i - 1

       while j >= 0 and sort[j] > key:
           sort[j + 1] = sort[j]
           j -= 1
       sort[j + 1] = key

   return sort


if __name__ == "__main__":
   sort = [5, 9, 3, 1, 2, 8, 4, 7, 6]
   print(insertSort(sort))

以上三种算法均是排序算法当中常用到的,或者面试中常问的算法;三个算法的时间复杂度都为O(n2),如果要想使时间更短的话,那么大家就要去考虑下其他的算法或者去了解下堆这个概念和分治思想。

相关文章
|
11月前
|
搜索推荐 算法 索引
冒泡排序算法的实现和优化~
冒泡排序算法的实现和优化~
|
搜索推荐 算法
|
4月前
|
算法 搜索推荐
【六大排序详解】中篇 :选择排序 与 堆排序
选择排序可以用扑克牌理解,眼睛看一遍所有牌,选择最小的放在最左边。然后略过刚才排完的那张,继续进行至扑克牌有序。这样一次一次的挑选,思路很顺畅。总结为: 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完 。
34 6
|
4月前
|
算法 搜索推荐
【算法基础】基础算法(一)--(快速排序、归并排序、二分)
【算法基础】基础算法(一)--(快速排序、归并排序、二分)
|
4月前
|
人工智能 搜索推荐
【hoare基础版】快速排序算法(1)
【hoare基础版】快速排序算法(1)
64 0
|
4月前
|
机器学习/深度学习 算法 搜索推荐
快速排序:高效分割与递归,排序领域的王者算法
快速排序:高效分割与递归,排序领域的王者算法
61 1
|
11月前
|
搜索推荐 算法
深入探究排序算法:快速排序的实现与优化
排序算法是计算机科学中的基础知识,它们在各种应用和场景中都扮演着重要角色。本文将深入探讨一种经典的排序算法——快速排序,并介绍其实现原理及优化技巧。
73 1
|
11月前
|
搜索推荐 算法
深入浅出排序算法之直接插入排序(拓展:折半插入排序)
深入浅出排序算法之直接插入排序(拓展:折半插入排序)
|
11月前
|
搜索推荐
插入排序算法的实现和优化~
插入排序算法的实现和优化~
|
测试技术
【八大排序(八)】归并排序高阶篇-非递归版
【八大排序(八)】归并排序高阶篇-非递归版