Python/ciphers/cryptomath_module.py

16 lines
429 B
Python
Raw Normal View History

def gcd(a: int, b: int) -> int:
2016-08-07 15:48:46 +00:00
while a != 0:
a, b = b % a, a
return b
2019-10-05 05:14:13 +00:00
def find_mod_inverse(a: int, m: int) -> int:
2016-08-07 15:48:46 +00:00
if gcd(a, m) != 1:
raise ValueError(f"mod inverse of {a!r} and {m!r} does not exist")
2016-08-07 15:48:46 +00:00
u1, u2, u3 = 1, 0, a
v1, v2, v3 = 0, 1, m
while v3 != 0:
q = u3 // v3
2019-10-05 05:14:13 +00:00
v1, v2, v3, u1, u2, u3 = (u1 - q * v1), (u2 - q * v2), (u3 - q * v3), v1, v2, v3
return u1 % m