Master theorem - Wikipedia, the free encyclopedia
In the analysis of algorithms, the master theorem provides a solution in asymptotic terms (using Big O notation) for recurrence relations of types that occur in the analysis of many divide and conquer algorithms.
Algorithms such as above can be represented as a recurrence relation
. This recursive relation can be successively substituted into itself and expanded to obtain expression for total amount of work done.
data:image/s3,"s3://crabby-images/27f7b/27f7b162d85f833485f22c968e30d21b07f86364" alt="T(n) = \Theta\left( n^{\log_b a} \right) = \Theta\left( n^{3} \right)"
data:image/s3,"s3://crabby-images/22ab7/22ab70516e5ef58969ed902da805c7639042fb4e" alt="T(n) = 2 T\left(\frac{n}{2}\right) + 10n"
Read full article from Master theorem - Wikipedia, the free encyclopedia
In the analysis of algorithms, the master theorem provides a solution in asymptotic terms (using Big O notation) for recurrence relations of types that occur in the analysis of many divide and conquer algorithms.
Algorithms such as above can be represented as a recurrence relation
The master theorem concerns recurrence relations of the form:
In the application to the analysis of a recursive algorithm, the constants and function take on the following significance:
then:
Example
If it is true, for some constant k ≥ 0, that:
where
then:
Case 3:
If it is true that:
where
and if it is also true that:
for some constant
and sufficiently large
(often called the regularity condition)
then:
Example
So it follows from the third case of the master theorem:
Application to common algorithms
Algorithm | Recurrence Relationship | Run time | Comment |
---|---|---|---|
Binary search | Apply Master theorem case | ||
Binary tree traversal | Apply Master theorem case | ||
Optimal Sorted Matrix Search | Apply Akra-Bazzi theorem for | ||
Merge Sort | Apply Master theorem case |