八大排序/八大排序口述版/八大排序面试版/八大排序思路(冒泡排序/选择排序/插入排序/希尔排序/归并排序/快速排序/堆排序/基数排序)

在算法和开发的面试中,经常会让你口述一下排序的某个算法的原理和思路,我整理了一下这八大排序的口述思路

1、冒泡排序

  1. 第一个数和第二个数比较,第一个数大则交换
  2. 第二个数和第三个数交换,第三个数大则交换
  3. 一直到最后一个数,则此时最后一个数为最大,最后一个数进入了已排序序列
  4. 重复1-3步骤,继续对前面n-1个数进行排序,完成排序

2、选择排序

  1. 第一步:选择第一个数的索引为最小数的索引
  2. 第二步:对剩下n-1个数进行遍历比较,遇到比当前最小索引数小的数,则更新最小索引
  3. 第三步:将新的最小索引数与第一个数进行交换,第一个数进入已排序序列(如果最小索引没有发生过变化,则不需要交换)
  4. 第四步:重复1-3步骤,继续对后面n-1个数进行排序,完成排序

3、插入排序

  1. 将第一个数与第二个数比较,第一个数大则交换,前面两个数进入已排序序列,第三个数为未排序序列的第一个数
  2. 未排序序列的数与已排序序列的所有数进行比较,将当前未排序序列的数插入到已排序序列的数
  3. 重复这个过程,完成排序

4、希尔排序

希尔排序也是插入排序的一种,对直接插入排序进行了改进,它采用了一种分组的策略使用直接插入排序,让排序的效率变得更高。分组数(也就是常说的gap,增量)

  1. 设为gap = n/2,向下取整,对gap个分组的每个小组的数进行直接插入排序
  2. 将gap更新为gap = gap /2,向下取整,对gap个分组的每个小组的数进行直接插入排序
  3. 重复这个过程直到gap为1,就是一个分组,即对整个数组进行一次直接插入排序

比如有10个数,第一次分组数就是10/2=5,这个5个分组对应的数的序号为:

(1,6)(2,7)(3,8)(4,9)(5,10)

对5个小组的所有数都进行一次直接插入排序

第二次分组数为5/2 = 2,这2个分组对应的数的序号为:

(1,3,5,7,9)(2,4,6,8,10)

对2个小组的所有数都进行一次直接插入排序

5、归并排序

归并排序

主要采用分割和合并的思路进行排序

  1. 将数组按照最中间索引,分割为左右两个数组(奇数个数的数组左右两个数组的元素个数相差为1)
  2. 将左右两个数组继续分割为左右两个数组,直到分割到数组只有一个元素
  3. 创建一个空的数组,依次遍历左右数组,比较左右数组的第一个元素的大小,较小的那个元素从对应数组中弹出
  4. 重复3的过程,直到两个数组的元素都弹出,即都合并到了新数组中
  5. 按照1、2分割的方式,重复3、4的过程,继续合并左右数组,直到合并至最后一个数组完成排序

因此可以看出归并排序需要的内存资源明显比较大(空间复杂度较高)

6、快速排序

相关推荐
yuhao__z3 分钟前
代码随想录算法训练营第五十六天| 图论2—卡码网99. 岛屿数量(dfs & bfs)
算法·深度优先·图论
小wanga28 分钟前
【算法专题十】哈希表
算法·哈希算法·散列表
S01d13r3 小时前
LeetCode 解题思路 45(分割等和子集、最长有效括号)
算法·leetcode·职场和发展
吃货界的硬件攻城狮4 小时前
【STM32 学习笔记】EXTI外部中断
笔记·stm32·学习
理想奋斗中4 小时前
【LeetCode Hot100 | 每日刷题】二叉树的层序遍历
算法·leetcode·bfs
吃货界的硬件攻城狮4 小时前
【STM32 学习笔记 】OLED显示屏及Keil调试
笔记·stm32·学习
njsgcs5 小时前
chili3d调试笔记12 deepwiki viewport svg雪碧图 camera three.ts
笔记
FBI HackerHarry浩5 小时前
Linux云计算训练营笔记day02(Linux、计算机网络、进制)
linux·运维·网络·笔记·计算机网络·进制
JCBP_6 小时前
C++(1)
开发语言·c++·算法
数据与人工智能律师6 小时前
互联网法院在NFT、元宇宙等新兴领域的规则创新
大数据·网络·人工智能·算法·区块链