1、什么是复杂度?

1、复杂度理解

  • 程序执行时需要的计算量和内存空间(和代码是否简洁无关)

  • 复杂度是数量级 (方便记忆、推广),不是具体的数字

  • 一般针对一个具体的算法,而非一个完整的系统

在这里插入图片描述

2、时间复杂度 - 程序执行时需要的计算量(CPU)

  • O(1) 一次就够 (数量级)
  • O(n) 和传输的数据量一样 (数量级)
  • O(n^2) 数据量的平方 (数量级)
  • O(logn) 数据量的对数 (数量级)
  • O(n * logn) 数据量 * 数据量的对数 (数量级)

O(1)代码示例

function fn(obj = {}) {
    // O(1)
    return obj.a + obj.b + obj.c // 4-5
}

以上代码没有循环,从对象取一个属性算一次计算量,做加分算一次计算量,都是属于常量级别的数量级,即O(1)。

O(n)代码示例

function fn(arr = []) {
    // O(n)
   for (let i = 0; i < arr.length; i++) {
       console.info(arr[i])
   }
}

以上代码的计算量和数组长度成正比,长度是10,计算量就是10,所以这里的计算量是O(n)。

O(n^2)代码示例

function fn(arr = []) {
    // O(n^2)
   for (let i = 0; i < arr.length; i++) {
       for (let j = 0; j < arr.length; j++) {
           console.info(arr[j])
       }
   }
}

以上代码并无实际意义,只谈论计算量,这里是双层循环,当外层循环一次,内层循环n次;当外层循环n次,内层循环n * n次,所以这里的计算量是O(n^2)。

O(logn)代码示例

其实就是一个二分计算

O(n * logn) 代码示例

就是一个循环嵌套一个二分运算

3、空间复杂度 - 程序执行时需要的内存空间

  • O(1) 有限的、可数的空间 (数量级)
  • O(n) 和输入的数量级相同的空间 (数量级)

O(1) 代码示例

function fn (arr = []) {
    // O(1)
    const a = arr[1]
    const b = arr[2]
    // ...
}

在这里这种平铺直叙的给变量分配一个空间,它的复杂度就是O(1)。

O(n) 代码示例

function fn(arr = []) {
    const arr2 = [];
    
    for(let i = 0; i < arr.length; i++) {
        arr2[i] = arr[i] + 10
    }
    // ...
}

这里可以看出定义的数组arr2的空间大小与arr的长度成正比的关系,所以这里的空间复杂度是O(n)。

程序员必须掌握算法复杂度

  • 如果你没有复杂度的概念和敏感度,写程序是非常危险的
  • 例如,代码功能测试正常,但数量大了,程序就会崩溃
  • 对应前端开发,尤其注重时间复杂度(前端:重时间,轻空间)
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

天界程序员

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

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

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

打赏作者

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

抵扣说明:

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

余额充值