取模与加减乘除原理,模拟实现代码及相关公式推导

计算(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)

实现代码

cpp 复制代码
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;
}
相关推荐
aaaweiaaaaaa3 分钟前
c++基础学习(学习蓝桥杯 ros2有C基础可看)
c++·学习·蓝桥杯·lambda·ros2·智能指针·c++类
skytier11 分钟前
Construct内报错和定位解决
算法
skytier15 分钟前
Ascend print数据落盘使用
算法
一拳一个呆瓜24 分钟前
【MFC】对话框属性:字体 (Font Name) 和 大小 (Font Size)
c++·mfc
etcix31 分钟前
dmenux.c: integrate dmenu project as one file
c语言·前端·算法
papership31 分钟前
【入门级-算法-6、排序算法:选择排序】
数据结构·算法·排序算法
郝学胜-神的一滴37 分钟前
基于OpenGL封装摄像机类:视图矩阵与透视矩阵的实现
c++·qt·线性代数·矩阵·游戏引擎·图形渲染
啊?啊?1 小时前
14 C++ STL 容器实战:stack/list 模拟实现指南 + priority_queue 用法及避坑技巧
c++·
汉克老师1 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(4、最大空白区)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
共享家95271 小时前
优先搜索(DFS)实战
算法·leetcode·深度优先