时间复杂度

时间复杂度


来自: http://baike.baidu.com/link?url=Tq2j4Msh3KhOwQ7dBiS49aBStSNIHMqJod_2aO8-Kuk9LyVVLDP2GwIYybkopXjwo_qf3QS4nJ4gKHwSoANlmq

  • 一个算法的评价主要从 “时间复杂度” 和 “空间复杂度” 来考虑。

  • 一个算法中的语句执行次数称为语句频度或时间频度。记为T(n)

在计算时间复杂度的时候,先找出算法的基本操作,然后根据相应的各语句确定它的执行次数,

再找出 T(n) 的同数量级(它的同数量级有以下:1,log2n,n,n log2n ,n的平方,n的三次方,2的n次方,n!),

找出后,f(n) = 该数量级,若 T(n)/f(n) 求极限可得到一常数c,

则时间复杂度T(n) = O(f(n))

例:

for(i=1; i<=n; ++i) {
    for(j=1; j<=n; ++j) {
        c[i][j] = 0;//该步骤属于基本操作执行次数:n的平方次
        for(k=1; k<=n; ++k)
            c[i][j] += a[i][k] * b[k][j];//该步骤属于基本操作执行次数:n的三次方次
    }
}

T(n) = n^2 + n^3, 根据上面括号里的同数量级, 我们可以确定 f(n) = n^3 为 T(n) 的同数量级

因为: T(n)/f(n) 求极限可得到常数c

所以: 该算法的时间复杂度:T(n) = O(n^3)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值