dfs时间复杂度_时间复杂度、空间复杂度

时间复杂度的数学证明方法相对比较复杂,通常在工程实际中,会分析就好。

算法学习:反复模仿,不懂先放过,之后回头看,把经典算法牢记于心

Big O notation

注意: 只看最高复杂度的运算

常数时间复杂度
int 

对数时间复杂度
for

线性时间复杂度
for

平方, 2层循环嵌套
for

立方, 3层循环嵌套
for

指数级时间复杂度,递归
int 

递归如何分析时间复杂度?

答: 推荐画出 递归树

阶乘

常数系数可以忽略,在分析时不用考虑,只要说以上术语即可。

2cf6309181c287440b7aa29392dda471.png

主定理 Master Throrem

b1adbf2cc855381a53b0f1dd76b6d785.png

上述第四种是 归并排序所有排序算法,最优的办法是

思考题,计算时间复杂度

二叉树的遍历 -前序、中序、后序 ?

图的遍历?

搜索算法,DFS、BFS?

二分法?

面试编程四件套:

  1. 与面试官 反复沟通,搞清题目意思
  2. 所有可能的解决办法,并比较这些算法的时间和空间复杂度
  3. 找出 最优方案,优先选取 时间复杂度最优 的方法,时间复杂度也优的更好
  4. 开始写代码,测试程序

空间复杂度

  1. 数组的长度,就看数组开的长度
  2. 递归的深度,递归的最大深度,看一个例子: LeetCode官方题解-爬楼梯

Reference:

如何理解算法时间复杂度的表示法,例如 O(n²)、O(n)、O(1)、O(nlogn) 等?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值