取模与加减乘除原理,模拟实现代码及相关公式推导
计算(a + b)%N
(a + b)%N = (a % N + b % N) % N
计算(a - b)%N
(a - b)%N = (a % N - b % N) % N
计算(a * b)%N
引入x,y . x = (a % N),y = (b % N)
推导a = t1 * N + x,b = t2 * N + y;
(a * b) % N
= ((t1 * N + x) * (t2 * N + y) ) % N
= (x * y) % N
= ((a % N )*( b % N)) % N
(a * b) % N = ((a % N )*( b % N)) % N
计算(a / b) % N
(a / b) % N = (a * power(b , N - 2) ) % N N必须为质数!!!!
除法写成这样看会舒服一点
除法公式推导
原文链接
分享丨模运算的世界:当加减乘除遇上取模(模运算恒等式/费马小定理/组合数) - 力扣(LeetCode)
实现代码
const int N = 1e9 + 7;
long long quickPowerMod(long long base, long long exponent) {
long long result = 1; // 初始化结果为1
base %= N; // 先对底数取模
while (exponent > 0) {
if (exponent % 2 == 1) { // 如果指数是奇数
result = (result * base) % N; // 将当前的底数乘到结果中,并取模
}
base = (base * base) % N; // 底数自乘,并取模
exponent >>= 1; // 指数右移一位(相当于除以2)
}
return result;
}
int add(int a, int b) {
return (a % N + b % N) % N;
}
int sub(int a, int b) {
return add(a, -b);
}
int mul(int a, int b) {
return ((a % N) * (b % N)) % N;
}
int divi(int a, int b) {
return mul(a % N, quickPowerMod(b, N - 2) % N) % N;
}