programming-examples/java/Data_Structures/BinaryExponentiation.java

19 lines
407 B
Java
Raw Normal View History

2019-11-15 12:59:38 +01:00
// https://en.wikipedia.org/wiki/Exponentiation_by_squaring
public class BinaryExponentiation {
public static int pow(int x, int n, int mod) {
int res = 1;
for (long p = x; n > 0; n >>= 1, p = (p * p) % mod) {
if ((n & 1) != 0) {
res = (int) (res * p % mod);
}
}
return res;
}
// usage example
public static void main(String[] args) {
System.out.println(8 == pow(2, 3, 100));
}
}