【算法】模运算的技巧

同余定理

如果 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;
}

存在除法时

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

相关推荐
Old Uncle Tom3 分钟前
提示词编写规范
数据库·算法
火山口车神丶6 分钟前
如何借助AI进行模块封装DIY
javascript·人工智能·算法
MegaDataFlowers10 分钟前
15.三数之和
算法
贾斯汀玛尔斯1 小时前
每天学一个算法--一致性哈希(Consistent Hashing)
算法·哈希算法
无限进步_1 小时前
C++ 继承机制完全解析:从基础原理到菱形继承问题
java·开发语言·数据结构·c++·vscode·后端·算法
superior tigre1 小时前
45 跳跃游戏2
算法·leetcode·游戏
不知名的忻2 小时前
并查集(QuickUnion)
java·数据结构·算法·并查集
leo__5202 小时前
基于时延的麦克风声源定位 - C实现
c语言·开发语言·算法
攻防_SRC2 小时前
面向分组密码差分故障分析的属性推导与验证平台
人工智能·算法·机器学习
likerhood2 小时前
Java实现选择题选项乱序算法
java·开发语言·算法