02 经典排序算法

评价算法的优劣,采用BigO

时间复杂度、空间复杂度

常数阶:O(1),表示执行时间恒定的算法

对数阶:O(log2n),对数:如果a的x次方等于N(a>0,且a不等于1),那么数x叫做以a为底N的对数(logarithm),记作x=logaN, 。其中,a叫做对数的底数,N叫做真数。

线性阶:O(n)

线性对数阶:O(nlog2n)

平方阶:O(n^2)

所耗时间从小到大:O(1) < O(log2n) < O(n) < O(nlog2n) < O(n^2) < O(n^3)…< O(n^n)

十大经典排序算法

image.png

名词解释:

n:数据规模

k:"桶"的个数

In-place:占用常数内存,不占用额外内存

Out-place:占用额外内存

稳定性:排序后 2 个相等键值的顺序和排序之前它们的顺序相同

算法核心逻辑

选择排序:把第一个没有排序过的元素设置为最小值,然后遍历每个没有排序过的元素;

冒泡排序:相邻的数两两比较,左边数大于右边数,则交换;

插入排序:从第二个元素开始,右边的数小于左边的数,则插入(通过交换);

归并排序:将数组分成两半,左边排序,右边排序,然后进行合并(其中左排序和右排序都是递归调用该算法);

快速排序:

计数排序:

基数排序:

桶排序:

代码案例

对数器

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值