算法的时间空间复杂度,维度

算法:解决问题的方法和步骤。看一个算法是否优秀时,我们要考虑时间复杂度和空间复杂度。特别是时间复杂度。
一、时间复杂度
在这里插入图片描述

常见的时间复杂度有:
常数阶O(1)
对数阶O(logn) //等于O(log2n),2在下面,n在上面,一般把2省略
线性阶O(n)
线性对数阶O(nlogn)
平方阶O(n^2)
指数阶O(2^n)
阶乘O(n!)

O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(2^n) < O(n!)

1.O(1)
function int(n){
var i =n
var j = 3*n
return i+j
}

2.O(logn)
function int(n){
let i =1
while(i<=n){
i=i*2
return i
}
}

3.O(n)
function int(n){
let sum = 0
for(let i=0;i<n;i++){
sum+=i
}
return sum
}

4.O(m+n)
function int(m,n){
let sum = 0
for(let i=0;i<m;i++){
sum+=i
}
for(let i=0;i<n;i++){
sum+=i
}
return sum
}

5.O(mlogn) //m乘以logn
function int(m,n){
sum = 0
for(let i=0;i<m;i++){
for(let i=0;i<n;i++){
sum+=ij
j=j
2
}
}
return sum
}

6.O(n^2)
function int(n){
sum = 0
for(let i=0;i<n;i++){
for(let i=0;i<n;i++){
sum+=i*j
}
}
return sum
}

二、空间复杂度:算法占用内存的空间
在这里插入图片描述

三、其他
1、O是一个算法最坏情况的度量(悲观主义者喜欢这个符号)
2、Big Omega是最好情况的度量(favorite notation of optimist)
3、Big Theta表达了一个算法的区间,不会好于某某,不会坏于某某

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

前端段

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

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

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

打赏作者

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

抵扣说明:

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

余额充值