我对主定理的理解是,一个算法可以被递归地定义为:
a T(n/b) + O(n^d)
当a为子问题数量,n/b为子问题的大小,O(n^d)为子问题的重组时间。计算主定理的时间复杂度如下:
T(n) = { O(n^d) if d > log base b of a
{
{ O(n^d log n) if d = log base b of a
{
{ O(n^ (log base b of a) ) if d < log base b of a
我的问题是,如果重新组合时间没有表达为O(n^d)的形式,比如O(2^n)或O(log(n)),那么怎样确定时间复杂度呢?