The Master Theorem provides a quick method to Analyse Asymptotically the Recurrence Relations.
FOR DECREASING FUNCTIONS
If a Recurrence Relation is of the Form
`T(n)=aT(n-b)+f(n)`
Then, as per Master Theorem, we have Three Conditions depending on value of `a`
|
|
|
`O(n f(n))` |
|
`O(a^{\frac{n}{b}}f(n))` |
|
`O(f(n))` |
In any problem, our main motive is to find `a, f(n)` and `b`.
NOTE: Replace `f(n)` by it's asymptotic equivalent.
FOR DIVIDING FUNCTIONS
If a Recurrence Relation is of the Form
`T(n)= aT ( \frac{n}{b} ) + n^k(\log(n))^p`
then, as per the Master Theorem, we have six conditions depending on value of `a,b,k` and `p`
|
|
|
`\Theta(n^{\log_b a})` |
|
`\Theta(n^k(\log(n))^{p+1})` |
|
`\Theta(n^k\log(\log(n)))` |
|
`\Theta(n^k)` |
|
`\Theta(n^k(\log(n))^p)` |
|
`\Theta(n^k)` |
In any problem, our main motive is to find `a,b,k` and `p`.
But, why it works❔
The approach was first presented by Dorothea Haken, James Benjamin Saxe and Jon Louis Bentley.
The derivation is quite typical to understand. But, at basic level, the idea lies behind tree, height of tree and domination. After certain height, few terms begin to dominate.
REFERENCES AND FURTHER READINGS
- https://www.youtube.com/watch?v=CyknhZbfMqc
- https://www.youtube.com/watch?v=OynWkEj0S-s
- https://en.wikipedia.org/wiki/Master_theorem_(analysis_of_algorithms)
- https://people.csail.mit.edu/thies/6.046-web/master.pdf
- https://api.semanticscholar.org/CorpusID:3172705
- https://towardsdatascience.com/all-about-mater-theorem-with-its-proof-93455cdb6a4e
- http://cs.uok.edu.in/Files/79755f07-9550-4aeb-bd6f-5d802d56b46d/Custom/Ten%20Master%20Method.pdf