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

Show that Algorithm 5 uses \(O({(\log m)^2}\log n)\)bit operations to find \({b^n}\bmod m\)\({b^n}\bmod m\)

Short Answer

Expert verified

\(\)\(O({(\log m)^2}\log n)\)

There is additional modulo \(m\)outside the\(for - \) loop and thus the algorithm requires at most \(2{\log _2}n{(\log {}_2m)^2} + 1\)operations, while \(2{\log _2}n{(\log {}_2m)^2} + 1\)is \(O{(\log m)^2}\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

Step 1

Modular Exponentiation Algorithm

Procedure modular exponentiation (\(b\)integer,\(n = {({a_{k - 1}}{a_{k - 2}}...{a_1}{a_0})_2}\)\(m:\) positive integers)

\(x = 1\)

Power \( = b\bmod m\)

For \(i = 0\) to\(k - 1\)

Begin

If \({a_i} = 1\)then \(x = x(.power)\bmod m\)

\(power = (power.power)\bmod m\)

End

\(\{ xequal{b^n}\bmod m\} \)

02

Step 2

In worst case scenario, \({a_i} = 1\) for all \(i = 0,1,,..,k - 1\)such that we need to determine the two modulo m’s in each iteration of the\(For - \) loop. Since the\(For - \) loop ranges from\(0\) to\(k - 1\) , the \(For - \)loop iterates \(k\) times and thus there are at most\(2k\) bit operations in the operation of the\(For - \) loop (2 operations per iteration)

However, \({a_i} = 1\) for \(i = 0,1,,..,k - 1\)all is only possible when\(n = {2^k} - 1\), which is about \(n = {2^k}\)or equivalently\(k = \log {}_2n\).This then implies that implies that there are at most \(2k = 2\log {}_2n\) bit operations.

To determine the products \(x.power\)and \(power.power\)we require at most \(2\log {}_2m.{\log _2}m = {(\log {}_2m)^2}\)operations as\(x\) and \(power\)both have at most\(\log {}_2m\) digits (and we determine the product by multiplying each of the corresponding digits of the n digits and thus resulting product has at most \({(\log {}_2m)^2}\)digits.)

This then means we require that we require \(2{\log _2}n.{(\log {}_2m)^2} = 2{\log _2}n{(\log {}_2m)^2}\)operations to determine both the modulo m’s and the product in the \(For - \)loop.

Finally, there is additional modulo \(m\)outside the\(For - \) loop and thus the algorithm requires at most \(2{\log _2}n{(\log {}_2m)^2} + 1\)operations, while \(2{\log _2}n{(\log {}_2m)^2} + 1\)is \(O{(\log m)^2}\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

Study anywhere. Anytime. Across all devices.

Sign-up for free