Java版常用排序算法复杂度

分析&回答


算法复杂度分为时间复杂度和空间复杂度。其作用:

  • 时间复杂度是指执行这个算法所需要的计算工作量;
  • 空间复杂度是指执行这个算法所需要的内存空间;
    时间和空间都是计算机资源的重要体现,而算法的复杂性就是体现在运行该算法时的计算机所需的资源多少;
排序算法英文名称平均时间复杂度最好情况最坏情况空间复杂度排序方式稳定性
冒泡排序BubbleO(n²)O(n)O(n²)O(1)In-place稳定
选择排序SelectionO(n²)O(n²)O(n²)O(1)In-place不稳定
插入排序InsertionO(n²)O(n)O(n²)O(1)In-place稳定
希尔排序ShellO(n ㏒n)O(n ㏒²n)O(n ㏒²n)O(1)In-place不稳定
归并排序MergeO(n ㏒n)O(n ㏒n)O(n ㏒n)O(n)Out-place稳定
快速排序QuickO(n ㏒n)O(n ㏒n)O(n²)O(㏒n)In-place不稳定
堆排序HeapO(n ㏒n)O(n ㏒n)O(n ㏒n)O(1)In-place不稳定
计数排序CountingO(n + k)O(n + k)O(n + k)O(k)Out-place稳定
桶排序BucketO(n + k)O(n + k)O(n²)O(n + k)Out-place稳定
基数排序RadixO(n × k)O(n × k)O(n × k)O(n + k)Out-place稳定

反思&扩展


特别关注快速排序归并排序

O(x)是啥意思?

简单直观的 O(1) 、 O(n) 、O(log n) 复杂度说起

  • O(1) 表示一次操作即可直接取得目标元素(比如字典或哈希表),
  • O(n) 意味着先要检查 n 个元素来搜索目标
  • O(log n) 时间复杂度可能是在学二分搜索算法

image.png


喵呜面试助手: 一站式解决面试问题,你可以搜索微信小程序 [喵呜面试助手] 或关注 [喵呜刷题] -> 面试助手 免费刷题。如有好的面试知识或技巧期待您的共享!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喵呜刷题

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值