【算法】模运算的技巧

同余定理

如果 a - b 可以被 p 整除,那么 a % p = b % p。反之亦成立。

负数模正数的结果和修正

在 C++ 或 java 中,一个负数模上一个正数的结果是负数,正数模上正数的结果是正数。现在修正为不管是正数还是负数模上正数的结果都是正数。即:当计算时存在减法时,结果可能是负数,如果需要补正,就需要"模加模"的技巧:

((a - b)%p + p)% p ,即 ((a - b)%p + p)% p 等于 (a - b)%p 的绝对值。

只有加法和乘法时

计算的过程如果只有加法和乘法,并且要对最终结果取模,那么中间过程可以随便取模(位置、次数随意,可以处处取模)。在编程中的意义是可以防止中间结果溢出。

cpp 复制代码
#include <stdio.h>

int main() {
   
    printf("%d\n", (1 + 2 + 3 * 4 + 5 + 6 + 7 + 8 * 9 + 10 + 11 * 12 + 13 + 15) % 5); // 输出 0

    // 在任意位置取模
    printf("%d\n", (1 + 2%5 + 3 * 4 + 5 + 6%5 + 7 + 8 * 9 + 10%5 + 11 * 12 + 13 + 15) % 5); // 输出 0

    return 0;
}

存在除法时

计算的过程如果存在除法,并且要对最终结果取模,那么中间过程如果随便取模,会造成结果错误。解决方法是求逆元

相关推荐
先吃饱再说10 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰13 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术14 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六17 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术18 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize19 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode