T(n) = 2T(n/2) + 0(1)
T(n) = T(sqrt(n)) + 0(1)
In the first one I use substitution method for n, logn, etc; all gave me wrong answers.
Recurrence trees: I don’t know if I can apply as the root will be a constant.
Can some one help?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
Let’s look at the first one. First of all, you need to know T(base case). You mentioned that it’s a constant, but when you do the problem it’s important that you write it down. Usually it’s something like T(1) = 1. I’ll use that, but you can generalize to whatever it is.
Next, find out how many times you recur (that is, the height of the recursion tree).
nis your problem size, so how many times can we repeatedly divide n by 2? Mathematically speaking, what’s i whenn/(2^i) = 1? Figure it out, hold onto it for later.Next, do a few substitutions, until you start to notice a pattern.
T(n) = 2(2(2T(n/2*2*2) + θ(1)) + θ(1)) + θ(1)Ok, the pattern is that we multiply T() by 2 a bunch of times, and divide n by 2 a bunch of times. How many times?
itimes.T(n) = (2^i)*T(n/(2^i)) + ...For the big-θ terms at the end, we use a cute trick. Look above where we have a few substitutions, and ignore the T() part. We want the sum of the θ terms. Notice that they add up to
(1 + 2 + 4 + ... + 2^i) * θ(1). Can you find a closed form for1 + 2 + 4 + ... + 2^i? I’ll give you that one; it’s(2^i - 1). It’s a good one to just memorize, but here’s how you’d figure it out.Anyway, all in all we get
T(n) = (2^i) * T(n/(2^i)) + (2^i - 1) * θ(1)If you solved for
iearlier, then you know thati = log_2(n). Plug that in, do some algebra, and you get down toT(n) = n*T(1) + (n - 1)*θ(1).T(1) = 1. SoT(n) = n + (n - 1)*θ(1). Which is n times a constant, plus a constant, plus n. We drop lower order terms and constants, so it’s θ(n).Prasoon Saurav is right about using the master method, but it’s important that you know what the recurrence relation is saying. The things to ask are, how much work do I do at each step, and what is the number of steps for an input of size
n?