排序算法总结|基本思路

本文参考bobo老师的教学视频。

O(n^2)的算法

1. 选择排序

每次选最小的元素,放到前面排序部分的最后一个位置
 

2. 插入排序

每次从未排序部分取第一个元素,不断向前面排好序里的元素比大小+交换,直到插入合适位置
缺点:频繁交换位置,交换操作耗时
改进:前面排序部分后移,直到找到合适位置再将元素放入
优点:在近乎有序的时候,插入效果近似O(n)
 

3. 希尔排序(插入的改进)

出发点:插入在近乎有序的时候很快,所以希尔先在大跨度上排序,然后逐渐减小步长
 

4. 冒泡排序

 
 

O(nlogn)的算法

1. 归并排序

自定向上:从上到下分割,然后排序
自底向上:初始每2个元素一组排序,接着4个…
对比:
1)递归自顶向下稍快一些
2)自底向上适合用于链表(因为不需要直接访问)
 

2. 快速排序

2种思路:
1)前面记录小于key的元素,中间记录大于key,后面是未遍历的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值