我只需要使用迭代方法找到这种递归的复杂性:
T(n) = 4T(n/2) + (n^2)*logn
我知道你可以使用master方法解决这个(n^2)(logn)^2
问题,而且复杂性是,但我尝试使用迭代方法解决它,我得到了别的东西:
T(n) = 4 * T(n/2) + (n^2) * log(n) T(n/2) = 4 * T (n/4) + ((n/2)^2) * log(n/2) T(n/4) = 4 * T(n/8) + ((n/4)^2) * log(n/4) T(n) = 4 * (4 * (4 * T(n/8) + (n/4)^2 * log(n/4)) + (n/2)^2 * log(n/2)) + (n^2) * log(n) T(n) = 64T(n/8) + 16((n/4)^2) * log(n/4) + 4((n/2)^2) * log(n/2) + (n^2)log(n) T(n) = (4^i) * T(n/(2^i)) + 4^(i-1) * (n/(2^(i-1)))^2 * log(n/(2^(i-1)))
在使用i = logn之后,我得到该算法的复杂度为2 ^ n ..这是不正确的.
如果您将小心地解除递归,您将得到: .
现在复杂的总和变成了
当n/2^k = 1
或时,这种递归会耗尽自己k = log(n)
.在等式中将其替换回来:
,哪里c = T(1)
.
所以一切都由主导n^2 log^2(n)
,这是你的递归的复杂性.
PS实际上不需要近似求和,用初等数学很容易计算出它.