Dja*_*man 3 algorithm math big-o recurrence
我只需要使用迭代方法找到这种递归的复杂性:
T(n) = 4T(n/2) + (n^2)*logn
Run Code Online (Sandbox Code Playgroud)
我知道你可以使用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)))
Run Code Online (Sandbox Code Playgroud)
在使用i = logn之后,我得到该算法的复杂度为2 ^ n ..这是不正确的.
现在复杂的总和变成了
当n/2^k = 1或时,这种递归会耗尽自己k = log(n).在等式中将其替换回来:
所以一切都由主导n^2 log^2(n),这是你的递归的复杂性.
PS实际上不需要近似求和,用初等数学很容易计算出它.