Last active 1730124153

in python

Revision 0c2c130e0ccca83db68f04c742cf46ac077920c2

karatsuba_multipication.py Raw
1def karatsuba(x: int, y: int) -> int:
2 """Multiply 2 same lenght ints using the karatsuba algorithm"""
3 # base case
4 if x < 10 or y < 10:
5 return x * y
6
7 # Calculate the number of digits of the larger number
8 n = max(len(str(x)), len(str(y)))
9 n_2 = n // 2
10
11 # split in half
12 a, b = divmod(x, 10**n_2)
13 c, d = divmod(y, 10**n_2)
14
15 # Recursively compute
16 bd = karatsuba(b, d)
17 pq = karatsuba((b + a), (d + c))
18 ac = karatsuba(a, c)
19
20 # Combine
21 return (ac * 10 ** (2 * n_2)) + ((pq - ac - bd) * 10**n_2) + bd
22
23
24# test
25x = 9823892839835678
26y = 1239823892839834
27result = karatsuba(x, y)
28print(f"{x} x {y} = {result}")