【算法】模运算的技巧

同余定理

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

存在除法时

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

相关推荐
CoderCodingNo8 小时前
【NOIP】2011真题解析 luogu-P1003 铺地毯 | GESP三、四级以上可练习
算法
iFlyCai8 小时前
C语言中的指针
c语言·数据结构·算法
查古穆8 小时前
栈-有效的括号
java·数据结构·算法
再一次等风来8 小时前
近场声全息(NAH)仿真实现:从阵列实值信号到波数域重建
算法·matlab·信号处理·近场声全息·nah
汀、人工智能8 小时前
16 - 高级特性
数据结构·算法·数据库架构·图论·16 - 高级特性
大熊背8 小时前
利用ISP离线模式进行分块LSC校正的方法
人工智能·算法·机器学习
XWalnut9 小时前
LeetCode刷题 day4
算法·leetcode·职场和发展
蒸汽求职9 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
AI成长日志9 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
旖-旎10 小时前
分治(库存管理|||)(4)
c++·算法·leetcode·排序算法·快速选择算法