C++ Program to Implement Modular Exponentiation algorithm

Modular exponentiation is a base fundamental algoritm in number theory and cryptography that works to efficiently find the remainder of an integer raised to a power then divided by another integer. This algorithm proves to be quite productive in cases where working with large numbers is involved - such as in cryptographic applications, RSa encryption being but one example.

The algorithm takes advantage of the fact that (a.b) mod n is equivalent to (a mod n⋅b mod n) mod n, thus, during the exponentiation process, we can perform the modular reduction at each step in order to avoid huge intermediate results.

Mathematical concepts

Modular arithmetic

Modular arithmetic is a subdiscipline of number theory devoted to arithmetic operations performed on integers subject to modulus restriction. Regarding modular exпonentiation, while concerned with the modulo operation, notated as a mod n, which provides the remainder when a is divided by n.

Key properties of modular arithmetic:

addition: (a+b) mod n=((a mod n)+(b mod n)) mod n.

Multiplication: (a.b) mod n=(((a mod n).(b.mod n)) mod n) mod n.

Exponentiation

The modular exponential problem deals with efficiently deriving a^b mod n given integers a,b, and n.

approach-1: Basic Iterative approach for Modular Exponentiation

a fundamental iterative algorithm for modular exponential is the basic iterative approach. It has a loop that iteratively squares the base and reduce the result modulo n at each step. The merits of the smethod does lie in its simplicity and intelligibility, but above all, this method is an ideal choice for concepts related to the educational field acnd as a basis for understanding more advanced algorithms.

Program:

output:

Enter the base: 4
Enter the exponent: 3
Enter the modulus: 2
Result: 4^3 mod 2 = 0

Explanation:

The algorithm starts with setting the end result to 1 because any range raised to the energy of 0 is 1. after that it goes right into a loop that iterates through the bits of the exponent. This loop keeps until the exponent becomes 0.

Inside the loop:

  • checking the Exponent Bit:

It checks the following situation: if (exponent % 2 ==1), to ensure the current little bit of the exponent is set (1). If the bit is set, it approach that the corresponding energy of two is one of the very last result and the base multiplied with the contemporary end result.

  • Squaring the Base:

To take care of the following bit within the exponent, the base is squared. This is a critical optimization, as it enables the algorithm to calculate powers of two successfully.

  • Right Shifting the Exponent:

In the next round of the loop, the exponent shifts right, and this action is equivalent to dividing by 2.

This procedure continues until the exponent is equal to zero. Ultimately, the function returns the computed value.

The user is prompted to enter the base, response, and modulus in the main function. These values are then utilized to execute modular expression with the power function, and the outcome is shown.

Example Usage:

The use of the example in the main function demonstrates easy use as well as practicality of the modular exponential algorithm. However, it should be noted that this simple iterative method is not complicated at all, yet a more optimized approach in form of the binary exponention is mostly used instead for greater efficiency especially in big number applications.

complexity analysis:

Lastly, the c++ code given as an input for the codification of the simple iterative method using modular exponenaliation is time and space complex, which represents a valuable criterion to evaluate its computational efficiency and scalability.

Time complexity:

The number of bit in the binary representation of the exponent can be determined as the determining factor of time complexity of modular exponeniatation algorithm based on the number of iterations of loop. Let us denote the number of bits in the exponent by k.

Loop Iterations:

The while loop in the power function iterate once through each bit of the exponent. The expiration is right-shifted (divided by D) with each iteration until it reaches zero so the loop is worked for o (k) times.

operations Inside the Loop:

The loop is performed simple arithmetical operations, for example, modular multiplication and division by 2 in each iteration. These opérations never stop in each iteration.

This means that the overall order of time complexity for the elementary iterative scheme usage for modular exponentiation is o(k), in which k stands for bit of the exponent. This complexity proves to be a highly effective one that not only lets the algorithm deal with exponents of significant size, but also uses reasonable amount of resources needed to complete the task.

Space complexity:

Space complexity is an assessment of the memory that an algorithm needs to run it, including auxiliary space and input space.

auxiliary Space:

The algorithm requires constant auxiliary space, independent of the size of the input. Result, base, exponent, and modulus are the only variables that consume space, with each one requiring a constant amount of space for storage.

Input Space:

The input space is determined by the size of the input values: base, exponent, and modulus. as these values are entered by the user and depend not on the size of the input.

Therefore, the total space cromplexity of the base iterative approach for the moduler exponentiation is o(1), showing that the algorithm uses constant amount of memory.


Next TopicC++ MCQ