hashmap时间和空间复杂度_时间复杂度、空间复杂度

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

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

Big O notation

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

equation?tex=O%281%29 常数时间复杂度
int n = 100;
System.out.println(“your input is:” + n);

equation?tex=O%28log+%28n%29%29 对数时间复杂度
for(int i = 1; i < n; i = i * 2){
    System.out.println(“your input is:” + i);
}

equation?tex=O%28n%29 线性时间复杂度
for(int i = 0; i < n; i++){
    System.out.println(“print:” + i);
}

equation?tex=O%28n%5E2%29 平方, 2层循环嵌套
for(int i = 0; i < n; i++){
    for(int j = 0; j < n; j++){
        System.out.println(“print:” + i + "," + j);
    }
}

equation?tex=O%28n%5E3%29 立方, 3层循环嵌套
for(int i = 0; i < n; i++){
    for(int j = 0; j < n; j++){
        for(int k = 0; k < n; k++){
            System.out.println(“print:” + i + "," + "j" + "," + k);
        }
    }
}

equation?tex=O%282%5En%29 指数级时间复杂度,递归
int fib(int n){
    if(n < 2) return n;
    return fib(n - 1) + fib(n- 2);
}

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

答: 推荐画出 递归树

equation?tex=O%28n%21%29 阶乘

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

8c9e17fa64a7d5f74bad1d78221fd9ba.png

主定理 Master Throrem

d6a0f045792d500915293fc8a2c890b5.png

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

equation?tex=O%28nlog%28n%29%29

思考题,计算时间复杂度

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

equation?tex=O%28n%29

图的遍历?

equation?tex=O%28n%29

搜索算法,DFS、BFS?

equation?tex=O%28n%29

二分法?

equation?tex=++++++O%28log%28n%29%29

面试编程四件套:

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

空间复杂度

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

Reference:

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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值