Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Can someone help solve this recurrence relation? [closed]

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?

like image 226
rda3mon Avatar asked Oct 18 '10 03:10

rda3mon


People also ask

How do you find the closed form of recurrence relations?

Solving a recurrence relation employs finding a closed-form solution for the recurrence relation. An equation such as S(n) = 2n, where we can substitute a value for n and get the output value back directly, is called a closed- form solution.

What is the solution of the recurrence relation?

Detailed Solution If r is the repeated root of the characteristics equation then the solution to recurrence relation is given as a n = a r n + b n r n where a and b are constants determined by initial conditions.

How do you calculate recurrence relations?

A recurrence or recurrence relation defines an infinite sequence by describing how to calculate the n-th element of the sequence given the values of smaller elements, as in: T(n) = T(n/2) + n, T(0) = T(1) = 1.


1 Answers

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). n is your problem size, so how many times can we repeatedly divide n by 2? Mathematically speaking, what's i when n/(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? i times.

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 for 1 + 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 i earlier, then you know that i = log_2(n). Plug that in, do some algebra, and you get down to

T(n) = n*T(1) + (n - 1)*θ(1). T(1) = 1. So T(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?

like image 190
johncip Avatar answered Oct 14 '22 13:10

johncip