Python/maths/modular_exponential.py

26 lines
489 B
Python
Raw Normal View History

"""Modular Exponential."""
2018-10-19 12:48:28 +00:00
def modular_exponential(base, power, mod):
"""Calculate Modular Exponential."""
if power < 0:
return -1
base %= mod
result = 1
while power > 0:
if power & 1:
result = (result * base) % mod
power = power >> 1
base = (base * base) % mod
return result
2018-10-19 12:48:28 +00:00
def main():
"""Call Modular Exponential Function."""
print(modular_exponential(3, 200, 13))
2018-10-19 12:48:28 +00:00
2019-10-05 05:14:13 +00:00
if __name__ == "__main__":
main()