时间复杂度
一个算法的评价主要从 “时间复杂度” 和 “空间复杂度” 来考虑。
一个算法中的语句执行次数称为语句频度或时间频度。记为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)