求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)

参考#

 1、如何用C中的运算符求mod(2的次方)?

 2、ZUC算法实现

作者:Hang Shao

出处:https://www.cnblogs.com/pam-sh/p/14555139.html

版权:本作品采用「知识共享」许可协议进行许可。

声明:欢迎交流! 原文链接 ,如有问题,可邮件(mir_soh@163.com)咨询.

posted @   PamShao  阅读(300)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
menu