Master's Theorem
Master's Theorem
Master's Theorem
Master Theorem
In the last section, we saw three different kinds of behavior for recurrences of the form
aT (n/2) + n if n > 1
T (n) =
d if n = 1.
These behaviors depended upon whether a < 2, a = 2, and a > 2. Remember that a was the
number of subproblems into which our problem was divided. Dividing by 2 cut our problem size
in half each time, and the n term said that after we completed our recursive work, we had n
additional units of work to do for a problem of size n. There is no reason that the amount of
additional work required by each subproblem needs to be the size of the subproblem. In many
applications it will be something else, and so in Theorem 5.1 we consider a more general case.
Similarly, the sizes of the subproblems don’t have to be 1/2 the size of the parent problem. We
then get the following theorem, our first version of a theorem called the Master Theorem. (Later
on we will develop some stronger forms of this theorem.)
Theorem 5.1 Let a be an integer greater than or equal to 1 and b be a real number greater than
1. Let c be a positive real number and d a nonnegative real number. Given a recurrence of the
form
aT (n/b) + nc if n > 1
T (n) =
d if n = 1
then for n a power of b,
Proof: In this proof, we will set d = 1, so that the bottom level of the tree is equally well
computed by the recursive step as by the base case. It is straightforward to extend the proof for
the case when d = 1.
Let’s think about the recursion tree for this recurrence. There will be logb n levels. At each
level, the number of subproblems will be multiplied by a, and so the number of subproblems at
level i will be ai . Each subproblem at level i is a problem of size (n/bi ). A subproblem of size
n/bi requires (n/bi )c additional work and since there are ai problems on level i, the total number
of units of work on level i is
i
i i c c ai c a
a (n/b ) = n =n .
bci bc
Recall from above that the different cases for c = 1 were when the work per level was
decreasing, constant, or increasing. The same analysis applies here. From our formula for work
on level i, we see that the work per level is decreasing, constant, or increasing exactly when ( bac )i
5.2. THE MASTER THEOREM 171
is decreasing, constant, or increasing. These three cases depend on whether ( bac ) is 1, less than
1, or greater than 1. Now observe that
( bac ) = 1
⇔ a = bc
⇔ logb a = c logb b
⇔ logb a = c
Thus we see where our three cases come from. Now we proceed to show the bound on
T (n) in the different cases. In the following paragraphs, we will use the facts (whose proof is a
straightforward application of the definition of 1ogartihms and rules of exponents) that for any
x, y and z, each greater than 1, xlogy z = z logy x and that logx y = Θ(log2 y). (See Problem 3 at
the end of this section and Problem 4 at the end of the previous section.)
In general, we have that the total work done is
logb n
i logb n
i
a a
nc = nc
i=0
bc i=0
bc
In case 1, (part 1 in the statement of the theorem) this is nc times a geometric series with a ratio
of less than 1. Theorem 4.4 tells us that
logb n i
a
c
n = Θ(nc ).
i=0
bc
a
In Case 2 we have that bc = 1 and so
logb n i logb n
a
nc = nc 1i = nc (1 + logb n) = Θ(nc log n) .
i=0
bc i=0
a
In Case 3, we have that bc > 1. So in the series
logb n
i logb n
i
c a c a
n =n ,
i=0
bc i=0
bc
a logb n
the largest term is the last one, so by Theorem 4.4,the sum is Θ nc bc . But
logb n
c a alogb n
n = nc
bc (bc )logb n
nlogb a
= nc log bc
n b
nlogb a
= nc
nc
logb a
= n .
172 CHAPTER 5. RECURSION AND RECURRENCES
So far, we have considered divide and conquer recurrences for functions T (n) defined on integers
n which are powers of b. In order to consider a more realistic recurrence in the master theorem,
namely
aT (n/b) + nc if n > 1
T (n) =
d if n = 1,
or
aT (n/b) + nc if n > 1
T (n) =
d if n = 1,
or even
a T (n/b) + (a − a )T (n/b) + nc if n > 1
T (n) =
d if n = 1,
it turns out to be easiest to first extend the domain for our recurrences to a much bigger set than
the nonnegative integers, either the real or rational numbers, and then to work backwards.
For example, we can write a recurrence of the form
f (x)t(x/b) + g(x) if x ≥ b
t(x) =
k(x) if 1 ≤ x < b
for two (known) functions f and g defined on the real [or rational] numbers greater than 1 and
one (known) function k defined on the real [or rational] numbers x with 1 ≤ x < b. Then so long
as b > 1 it is possible to prove that there is a unique function t defined on the real [or rational]
numbers greater than or equal to 1 that satisfies the recurrence. We use the lower case t in this
situation as a signal that we are considering a recurrence whose domain is the real or rational
numbers greater than or equal to 1.
when f and g are (known) functions defined on the positive integers, and k and b
are (known) constants with b an integer larger than or equal to 2? (Note that n/b
denotes the ceiling of n/b, the smallest integer greater than or equal to n/b. Similarly
x denotes the floor of x, the largest integer less than or equal to x.)
5.2. THE MASTER THEOREM 173
To compute t(7) in Exercise 5.2-3 we need to know t(7/2). To compute t(7/2), we need to
know t(7/4). Since 1 < 7/4 < 2, we know that t(7/4) = 35/4. Then we may write
35 49 154 77
t(7/2) = 3 · + = = .
4 4 4 2
Next we may write
t(7) = 3t(7/2) + 72
77
= 3· + 49
2
329
= .
2
Clearly we can compute t(x) in this way for any x, though we are unlikely to enjoy the arithmetic.
On the other hand suppose all we need to do is to show that there is a unique value of t(x)
determined by the recurrence, for all real numbers x ≥ 1. If 1 ≤ x < 2, then t(x) = 5x, which
uniquely determines t(x). Given a number x ≥ 2, there is a smallest integer i such that x/2i < 2,
and for this i, we have 1 < x/2i . We can now prove by induction on i that t(x) is uniquely
determined by the recurrence relation.
In Exercise 5.2-4 there is one and only one solution. Why? Clearly T (1) is determined by
the recurrence. Now assume inductively that n > 1 and that T (m) is uniquely determined for
positive integers m < n. We know that n ≥ 2, so that n/2 ≤ n − 1. Since b ≥ 2, we know
that n/2 ≥ n/b, so that n/b ≤ n − 1. Therefore n/b < n, so that we know by the inductive
hypothesis that T (n/b) is uniquely determined by the recurrence. Then by the recurrence,
n
T (n) = f (n)T + g(n),
b
which uniquely determines T (n). Thus by the principle of mathematical induction, T (n) is
determined for all positive integers n.
For every kind of recurrence we have dealt with, there is similarly one and only one solution.
Because we know solutions exist, we don’t find formulas for solutions to demonstrate that solu-
tions exist, but rather to help us understand properties of the solutions. In the last section, for
example, we were interested in how fast the solutions grew as n grew large. This is why we were
finding Big-O and Big-Θ bounds for our solutions.
We will now show how recurrences for arbitrary real numbers relate to recurrences involving
floors and ceilings. We begin by showing that the conclusions of the Master Theorem apply to
recurrences for arbitrary real numbers when we replace the real numbers by “nearby” powers of
b.
Theorem 5.2 Let a and b be positive real numbers with b > 1 and c and d be real numbers. Let
t(x) be the solution to the recurrence
at(x/b) + xc if x ≥ b
t(x) =
d if 1 ≤ x < b.
174 CHAPTER 5. RECURSION AND RECURRENCES
where n is a nonnegative integer power of b. Let m(x) be the smallest integer power of b greater
than or equal to x. Then t(x) = Θ(T (m(x)))
Proof: If iterate (or, in the case that a is an integer, draw recursion trees for) the two
recurrences, we can see that the results of the iterations are nearly identical. This means the
solutions to the recurrences have the same big-Θ behavior. See the Appendix to this Section for
details.
We have also pointed out that a more realistic Master Theorem would apply to recurrences of
the form T (n) = aT (n/b) + nc , or T (n) = aT (n/b) + nc , or even T (n) = a T (n/b) + (a −
a )T (n/b) + nc . For example, if we are applying mergesort to an array of size 101, we really
break it into pieces, one of size 50 and one of size 51. Thus the recurrence we want is not really
T (n) = 2T (n/2) + n, but rather T (n) = T (n/2) + T (n/2) + n.
We can show, however, that one can essentially “ignore” the floors and ceilings in typical
divide-and-conquer recurrences. If we remove the floors and ceilings from a recurrence relation,
we convert it from a recurrence relation defined on the integers to one defined on the rational
numbers. However we have already seen that such recurrences are not difficult to handle.
The theorem below says that in recurrences covered by the master theorem, if we remove
ceilings, our recurrences still have the same Big-Θ bounds on their solutions. A similar proof
shows that we may remove floors and still get the same Big-Θ bounds. The condition that b > 2
can be replaced by b > 1, but the base case for the recurrence will depend on b. Since we
may remove either floors or ceilings, that means that we may deal with recurrences of the form
T (n) = a T (n/b) + (a − a )T (n/b) + nc
Theorem 5.3 Let a and b be positive real numbers with b ≥ 2 and let c and d be real numbers.
Let T (n) be the function defined on the integers by the recurrence
aT (n/b) + nc if n > 1
T (n) = ,
d n=1
and let t(x) be the function on the real numbers defined by the recurrence
at(x/b) + xc if x ≥ b
t(x) = .
d if 1 ≤ x < b
Then T (n) = Θ(t(n)). The same statement applies with ceilings replaced by floors.
Proof: As in the previous theorem, we can consider iterating the two recurrences. It is
straightforward (though dealing with the notation is difficult) to show that for a given value of
n, the iteration for computing T (n) has at most two more levels than the iteration for computing
5.2. THE MASTER THEOREM 175
t(n). The work per level also has the same Big-Θ bounds at each level, and the work for the two
additional levels of the iteration for T (n) has the same Big-Θ bounds as the work at the bottom
level of the recursion tree for t(n). We give the details in the appendix at the end of this section.
Theorem 5.2 and Theorem 5.3 tell us that the Big-Θ behavior of solutions to our more realistic
recurrences
aT (n/b) + nc if n > 1
T (n) =
d n=1
We showed that in our version of the master theorem, we could ignore ceilings and assume our
variables were powers of b. In fact we can ignore them in circumstances where the function telling
us the “work” done at each level of our recursion tree is Θ(xc ) for some positive real number c.
This lets us apply the master theorem to a much wider variety of functions.
Theorem 5.4 Theorems 5.3 and 5.2 apply to recurrences in which the xc term is replaced by a
function f in which f (x) = Θ(xc ).
Proof: We iterate the recurrences or construct recursion trees in the same way as in the proofs
of the original theorems, and find that the condition f (x) = Θ(xc ) gives us enough information
to again bound one of the solutions above and below with a multiple of the other solution. The
details are similar to those in the original proofs.
√
Exercise 5.2-5 If f (x) = x x + 1, what can you say about the Big-Θ behavior of solutions
to
2T (n/3) + f (n) if n > 1
T (n) =
d if n = 1,
√ √
Since f (x) = x x + 1 ≥ x x = x3/2 , we have that x3/2 = O(f (x)). Since
√ √ √ √ √
x+1≤ x+x= 2x = 2 x
√ √ √ √
for x > 1, we have f (x) = x x + 1 ≤ 2x x = 2x3/2 = O(x3/2 ). Thus the big-Θ behavior of
the solutions to the two recurrences will be the same.
176 CHAPTER 5. RECURSION AND RECURRENCES
As Exercise 5.2-5 suggests, Theorem 5.4 opens up a whole range of interesting recurrences to
analyze. These recurrences have the same kind of behavior predicted by our original version of
the Master Theorem, but the original version of the Master Theorem does not apply to them,
just as it does not apply to the recurrences of Exercise 5.2-5.
We now state a second version of the Master Theorem. A still stronger version of the the-
orem may be found in CLR, but the version here captures much of the interesting behavior of
recurrences that arise from the analysis of algorithms. The condition that b ≥ 2 in this theorem
can be replaced by b > 1, but then the base case depends on b and is not the case with n = 1.
Theorem 5.5 Let a and b be positive real numbers with a ≥ 1 and b ≥ 2. Let T (n) be defined by
aT (n/b) + f (n) if n > 1
T (n) =
d if n = 1.
Then
1. if f (n) = Θ(xc ) where logb a < c, then T (n) = Θ(nc ) = Θ(f (n)).
Proof: Since we have assumed that f (n) = Θ(nc ), we know by Theorem 5.4 that we may
restrict our domain to exact powers of b. We mimic the original proof of the Master theorem,
substituting the appropriate Θ(nc ) for f (n) in computing the work done at each level. But this
means there are constants c1 and
i
c , independent of the level, so that the work at each level is
i 2
between c1 nc bac and c2 nc bac so from this point on the proof is largely a translation of the
original proof.
Exercise 5.2-6 What does the Master Theorem tell us about the solutions to the recur-
rence
√
3T (n/2) + n n + 1 if n > 1
T (n) =
1 if n = 1?
√ √ √
As we saw in our solution to Exercise 5.2-5 x x + 1 = Θ(x3/2 ). Since 23/2 = 23 = 8 < 3,
we have that log2 3 > 3/2. Then by conclusion 3 of version 2 of the Master Theorem, T (n) =
Θ(nlog2 3 ).
5.2. THE MASTER THEOREM 177
For convenience, we repeat the statements of the earlier theorems whose proofs we merely out-
lined.
Theorem 5.6 Let a and b be positive real numbers with b > 1 and c and d be real numbers. Let
t(x) be the solution to the recurrence
at(x/b) + xc if x ≥ b
t(x) =
d if 1 ≤ x < b.
where n is a nonnegative integer power of b. Let m(x) be the smallest integer power of b greater
than or equal to x. Then t(x) = Θ(T (m(x)))
Proof: By iterating each recursion 4 times (or using a four level recursion tree in the case
that a is an integer), we see that
x
a
3 a
2 a c
t(x) = a4 t + xc + xc + x
b4 bc bc bc
and n
a
3 a
2
a c
T (n) = a4 T + nc + n nc +
b4 bc bc bc
Thus continuing until we have a solution, in both cases we get a solution that starts with a raised
to an exponent that we will denote as either e(x) or e(n) when we want to distinguish between
them and e when it is unnecessary to distinguish. The solution will be ae times T (x/be ) plus
e
i
a
xc or nc times a geometric series G(x) = i=0 bc . In both cases T (x/be ) (or T (n/be )) will
e
be d. In both cases the geometric series will be Θ(1), Θ(e) or Θ bac , depending on whether bac
is less than 1, equal to 1, or greater than one. Clearly e(n) = logb n. Since we must divide x
by b an integer number greater than logb x − 1 times in order to get a value in the range from
1 to b, e(x) = logb x. Thus if m is the smallest integer power of b greater than or equal to
x, then 0 ≤ e(m) − e(x) < 1. Then for any real number r we have r0 ≤ re(m)−e(x) < r, or
re(x) ≤ re(m) ≤ r · re(x) . Thus we have re(x) = Θ(re(m) ) for every real number r, including r = a
and r = bac . Finally, xc ≤ mc ≤ bc xc , and so xc = Θ(mc ). Therefore, every term of t(x) is Θ of
the corresponding term of T (m). Further, there are only a finite number of different constants
involved in our Big-Θ bounds. Therefore since t(x) is composed of sums and products of these
terms, t(x) = Θ(T (m)).
Theorem 5.7 Let a and b be positive real numbers with b ≥ 2 and let c and d be real numbers.
Let T (n) be the function defined on the integers by the recurrence
aT (n/b) + nc if n ≥ b
T (n) =
d n = 1,
178 CHAPTER 5. RECURSION AND RECURRENCES
and let t(x) be the function on the real numbers defined by the recurrence
at(x/b) + xc if x ≥ b
t(x) =
d if 1 ≤ x < b.
Proof: As in the previous proof, we can iterate both recurrences. Let us compare what the
results will be of iterating the recurrence for t(n) and the recurrence for T (n) the same number
of times. Note that
This suggests that if we define n0 = n, and ni = ni−1 /b, then it is straightforward to prove
by induction that ni < n/bi + 2. The number ni is the argument of T in the ith iteration of the
recurrence for T . We have just seen it differs from the argument of t in the ith iteration of t
by at most 2. In particular, we might have to iterate the recurrence for T twice more than we
iterate the recurrence for t to reach the base case. When we iterate the recurrence for t, we get
the same solution we got in the previous theorem, with n substituted for x. When we iterate the
recurrence for T , we get for some integer j that
j−1
T (n) = aj d + ai nci ,
i=0
with bni ≤ ni ≤ bni + 2. But, so long as n/bi ≥ 2, we have n/bi + 2 ≤ n/bi−1 . Since the number of
iterations of T is at most two more than the number of iterations of t, and since the number of
iterations of t is logb n, we have that j is at most logb n + 2. Therefore all but perhaps the
last three values of ni are less than or equal to n/bi−1 , and these last three values are at most b2 ,
b, and 1. Putting all these bounds together and using n0 = n gives us
j−1 n
c
j−1
ai ≤ ai nci
i=0
bi i=0
j−4 n
c
≤ n + c
ai + aj−2 (b2 )c + aj−1 bc + aj 1c ,
i=1
bi−1
or
j−1 n
c
j−1
ai ≤ ai nci
i=0
bi i=0
c c c
j−4 n
c bj bj bj
≤ n +b c
a i
+a j−2
+a j−1 j
+a .
i=1
bi bj−2 bj−1 bj
As we shall see momentarily these last three “extra” terms and the b in front of the summation
sign do not change the Big-Θ behavior of the right-hand side.
5.2. THE MASTER THEOREM 179
As in the proof of the master theorem, the Big-Θ behavior of the left hand side depends on
whether a/bc is less than 1, in which case it is Θ(nc ), equal to 1, in which case it is Θ(nc logb n),
or greater than one in which case it is Θ(nlogb a ). But this is exactly the Big-Θ
j
cbehavior
of
the
c
b
j 2 j
right-hand side, because n < b < nb , so b = Θ(n), which means that bi = Θ bni ,
and the b in front of the summation sign does not change its Big-Θ behavior. Adding aj d to
the middle term of the inequality to get T (n) does not change this behavior. But this modified
middle term is exactly t(n).
1. Master Theorem, simplified version. The simplified version of the Master Theorem states:
Let a be an integer greater than or equal to 1 and b be a real number greater than 1. Let c
be a positive real number and d a nonnegative real number. Given a recurrence of the form
aT (n/b) + nc if n > 1
T (n) =
d if n = 1
2. Properties of Logarithms. For any x, y and z, each greater than 1, xlogy z = z logy x . Also,
logx y = Θ(log2 y).
when f and g are (known) functions defined on the positive integers, and k and b are
(known) constants with b an integer larger than 2 has a unique solution.
4. Recurrences Defined on the Positive Real Numbers and Recurrences Defined on the Positive
Integers. Let a and b be positive real numbers with b > 1 and c and d be real numbers.
Let t(x) be the solution to the recurrence
at(x/b) + xc if x ≥ b
t(x) =
d if 1 ≤ x < b.
where n is a nonnegative integer power of b. Let m(x) be the smallest integer power of b
greater than or equal to x. Then t(x) = Θ(T (m(x)))
180 CHAPTER 5. RECURSION AND RECURRENCES
5. Removing Floors and Ceilings from Recurrences. Let a and b be positive real numbers with
b ≥ 2 and let c and d be real numbers. Let T (n) be the function defined on the integers by
the recurrence
aT (n/b) + nc if n > 1
T (n) = ,
d n=1
and let t(x) be the function on the real numbers defined by the recurrence
at(x/b) + xc if x ≥ b
t(x) = .
d if 1 ≤ x < b
Then T (n) = Θ(t(n)). The same statement applies with ceilings replaced by floors.
6. Solutions to Realistic Recurrences. The theorems summarized in 4 and 5 tell us that the
Big-Θ behavior of solutions to our more realistic recurrences
aT (n/b) + nc if n > 1
T (n) =
d n=1
7. Master Theorem, More General Version. Let a and b be positive real numbers with a ≥ 1
and b ≥ 2. Let T (n) be defined by
aT (n/b) + f (n) if n > 1
T (n) =
d if n = 1
Then
(a) if f (n) = Θ(xc ) where logb a < c, then T (n) = Θ(nc ) = Θ(f (n)).
(b) if f (n) = Θ(nc ), where logb a = c, then T (n) = Θ(nlogb a logb n)
(c) if f (n) = Θ(nc ), where logb a > c, then T (n) = Θ(nlogb a ).
The same results apply with ceilings replaced by floors. A similar result with a base case
that depends on b holds when 1 < b < 2.
Problems
1. Use the master theorem to give Big-Θ bounds on the solutions to the following recurrences.
For all of these, assume that T (1) = 1 and n is a power of the appropriate integer.
2. Extend the proof of the Master Theorem, Theorem 5.1 to the case T (1) = d.
3. Show that for any x, y and z, each greater than 1, xlogy z = z logy x .
5.2. THE MASTER THEOREM 181
4. Show that for each real number x ≥ 0 there is one and only one value of T (x) given by the
recurrence
7xT (x − 1) + 1 if x ≥ 1
T (x) =
1 if 0 ≤ x < 1.
5. Show that for each real number x ≥ 1 there is one and only one value of T (x) given by the
recurrence
3xT (x/2) + x2 if x ≥ 2
T (x) = .
1 if 1 ≤ x < 2
if b < 2? If b = 10/9, what would we have to replace the condition that T (n) = k if n = 1
by in order to get a unique solution?