排序算法-常见

排序

冒泡排序

冒泡排序

  • 优缺点、复杂度
稳定,平均/最坏时间复杂度 O(n²),元素基本有序时最好时间复杂度 O(n),空间复杂度 O(1)
  • 步骤
    1. 从头开始,依次比较数组中相邻的2个元素,如果前面的数比后面的数大,则交换位置
    2. 每进行一轮比较,都会把数组中最大的元素放到最后面
    3. 针对 n 个元素重复以上步骤 n -1 次排序完毕

选择排序

选择排序

  • 优缺点、复杂度
不稳定,时间复杂度 O(n²),空间复杂度 O(1)
  • 步骤
    1. 将第一个值与全员比较,找到最小的那个值放在首位
    2. 排除第一个值,剩下的值重复步骤1,直到所有元素排序完毕

插入排序

插入排序

  • 优缺点、复杂度
稳定,平均/最差时间复杂度 O(n²),元素基本有序时最好时间复杂度 O(n),空间复杂度 O(1)
  • 步骤
    1. 将第一个元素作为有序数组
    2. 下一个元素从后遍历并插入到有序数组中,组成有序数组
    3. 重复步骤2,直到排序完毕

快速排序

在这里插入图片描述序

  • 优缺点、复杂度
不稳定,平均/最好时间复杂度 O(nlogn),元素基本有序时最坏时间复杂度O(n²),空间复杂度 O(logn)
  • 步骤
  1. 从数列中取出一个数作为基准数
  2. 分区:将比它大的数全放到它的右边,小于或等于它的数全放到它的左边
  3. 再对左右区间重复第二步,直到各区间只有一个数

堆排序

堆排序

  • 优缺点、复杂度
不稳定,时间复杂度 O(nlogn),空间复杂度 O(1)
  • 原理
    • 堆:近似完全二叉树的结构,堆中某个节点值总是不大于或者不小于其父节点的值
    • 根结点最大的堆叫做最大堆或大根堆,根结点最小的堆叫做最小堆或小根堆
  • 步骤
    1. 将排序元素组成大根堆或小根堆
    2. 取出根节点,将剩下元素再组成大根堆或小根堆
    3. 重复步骤2,直到元素为1
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值