当前位置: 首页 > article >正文

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


计算(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;
}


http://www.kler.cn/a/531167.html

相关文章:

  • C语言教程——文件处理(2)
  • 为什么LabVIEW适合软硬件结合的项目?
  • VSCode插件Live Server
  • 3 [通用GITHUB投毒免杀工具安装木马攻击活动的详细分析]
  • 使用 HTTP::Server::Simple 实现轻量级 HTTP 服务器
  • 索罗斯的“反身性”(Reflexivity)理论:市场如何扭曲现实?(中英双语)
  • 【线程】基于阻塞队列的生产者消费者模型
  • 【C语言篇】“三子棋”
  • kubernetes(二)
  • 对比JSON和Hessian2的序列化格式
  • 前端 | JavaScript中的reduce方法
  • 【14】WLC3504 HA配置实例
  • 【股票数据API接口49】如何获取股票实时交易数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
  • 自动化构建-make/Makefile 【Linux基础开发工具】
  • 本地快速部署DeepSeek-R1模型——2025新年贺岁
  • relational DB与NoSQL DB有什么区别?该如何选型?
  • C++ Primer 迭代器
  • Unity特效插件GodFX
  • 力扣经典题目之14. 最长公共前缀
  • Alibaba开发规范_异常日志之日志规约:最佳实践与常见陷阱
  • 最新功能发布!AllData数据中台核心菜单汇总
  • Win11使用VMware提示:平台不支持虚拟化的 Intel VT-x/EPT
  • 【BUUCTF逆向题】[WUSTCTF2020]level1、[GUET-CTF2019]re
  • linux通过lvm调整分区大小
  • 【Leetcode 每日一题】81. 搜索旋转排序数组 II
  • 【ChatGPT:开启人工智能新纪元】