Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Set up a divide-and-conquer recurrence relation for the number of modular multiplications required to compute \({a^n}\,\bmod \,\;m,\) where\(a,\;n\), and \(n\) are positive integers, using the recursive algorithms from Example 4 in Section 5.4.

b) Use the recurrence relation you found in part (a) to construct a big-\(O\)estimate for the number of modular multiplications used to compute\({a^n}\,\bmod \,\;m\)using the recursive algorithm.

Short Answer

Expert verified

(a) The number of modular multiplications required is\(f(n) = f(n/2) + 2\)

(b) The number of modular multiplications using the recursive algorithm is\(O(\log n)\)

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

Recurrence Relation and Master Theorem definition

A recurrence relation is an equation that recursively defines a sequence where the next term is a function of the previous terms: \({\rm{f(n) = a f(n / b) + c}}\)

In MASTER THEOREM, let \(f\)be an increasing function that satisfies the recurrence relation \(f(n) = af(n/b) + c{n^d}\) whenever\(n = {b^k}\), where \(k\) is a positive integer, \(a \ge 1,b\) is an integer greater than\(1\), and \(c\) and \(d\) are real numbers with \(c\) positive and \(d\) nonnegative. Then \(f(n)\) is \(O\left( {{n^d}} \right)\) if \(a < {b^d}{\rm{ }}O\left( {{n^d}\log n} \right)\) if \(a = {b^d}\) and\(O\left( {{n^{{{\log }_b}a}}} \right)\) if\(a > {b^d}\).

02

Apply Recurrence Relation

(a)

When\(n = 1\)then\({a^n}\,\bmod \,m = a\,\bmod \,m\).

When\(n\)even, then we first calculate\({a^{n/2}}\,\bmod \,m\)and then multiply the result\(y\)with itself (modulo\(m\)), thus 1 more multiplication then occurs.

When\(n\)odd, then we first calculate\({a^{(n - 1)/2}}\,\bmod \,m\)and then multiply the result\(y\)with itself and with\(a\)(modulo\(m\)), thus\(2\)more multiplication then occurs.

Thus in each recursive step, the number of multiplication is the number of multiplications for\(\frac{n}{2}\)(rounded down to the nearest integer) and then increased by at most 2 multiplications.

\(f(n) = f(n/2) + 2\)

03

Apply Master Theorem        

(b)

When\(f(n) = af(n/b) + c{n^d}\)then;

\(f(n) = \left\{ {\begin{array}{*{20}{c}}{O\left( {{n^d}} \right),}&{{\rm{ if }}a < {b^d}}\\{O\left( {{n^d}\log n} \right),}&{{\rm{ if }}a = {b^d}}\\{O\left( {{n^{{{\log }_b}a}}} \right),}&{{\rm{ if }}a > {b^d}}\\a&{ = 1}\\b&{ = 2}\\c&{ = 2}\\d&{ = 0}\end{array}} \right.\)

In this case,\(a = 1 = {2^0} = {b^d}\):\(O\left( {{n^d}\log n} \right) = O\left( {{n^0}\log n} \right) = O(\log n)\).

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free