求mod运算
求A mod B#
要求#
B必须是2的次方
方法#
A mod B = A & (B - 1)
程序#
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | #include <stdio.h> //10 mod 8 = 2 int addM(int a,int b) { return a & (b-1); // mod (2^31-1) } int main() { int result; int a=10; int b=8; result = addM(a,b); printf( "%d mod %d = %d\n" ,a,b,result); return 0; } |
原理#
求教~
求 A mod (2^31 -1)#
方法1#
1 | result = (A & 0x7FFFFFFF) + 1; |
参考ZUC代码
求解原因?
方法2#
1 | result = (A & 0x7FFFFFFF) + (A >> 31) |
参考ZUC国密标准
求解原因?
扩展:求 ab mod (2^31 -1)
参考#
2、ZUC算法实现
作者:Hang Shao
出处:https://www.cnblogs.com/pam-sh/p/14555139.html
版权:本作品采用「知识共享」许可协议进行许可。
声明:欢迎交流! 原文链接 ,如有问题,可邮件(mir_soh@163.com)咨询.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)