快速幂、龟速乘总结
快速幂、龟速乘总结
一、快速幂
求 的结果。
// 快速幂(不加mod)
int qmi(int a, int b) {
int res = 1;
while (b) {
if (b & 1) res = res * a;
b >>= 1;
a = a * a;
}
return res;
}
// 快速幂
int qmi(int a, int b) {
int res = 1;
while (b) {
if (b & 1) res = (res * a) % MOD;
b >>= 1;
a = a * a % MOD;
}
return res;
}
解释一下:
假如我们需要计算,正常的办法是
int s = 1;
for (int i = 1; i <= 10; i++) s = s * 2;
cout << s << endl;
毫无疑问,这个算法是正确的。但它执行的次数是次,有没有什么办法可以优化一下运算次数呢?
优化
将进行二进制分解
这样处理后,从后向前,借助于我们熟悉的数位分离模板,就是遍历二进制的每一位。
此时,我们发现,最左面的数字,权值是,第三位的数字权值是
同时,
为什么会有这么神奇的现象呢?其实就是因为幂运算的性质造成:
为啥非得拆成,为啥不拆成呢?
就是因为类似于 倍增 的办法在计算中好处理呗!
在代码中的使命就是:我不管你用不用的上,反正我每次是翻倍!
而枚举的每一个数位,就是看看这个位置上的当前是不是需要乘进来!幂运算的性质成功的把幂与二进制加法结合起来了。
把倍增的思路这样长上来的,这是因为
模板题 : 【模板】快速幂||取余运算
二、龟速乘
求 的结果, 都是 级别。
// 龟速乘,快速加
int qadd(int a, int b) {
int res = 0;
while (b) {
if (b & 1) res = (res + a) % MOD;
b >>= 1;
a = (a + a) % MOD;
}
return res;
}
这东西怎么理解呢?
举栗子吧:
最右侧的对就的权值是 ①
右侧第二的对就的权值是 ②
右侧第三的对就的权值是 ③
而对应的位置上有数字,有效,无效
结果就是
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
2013-11-13 广州项目实施步骤III_练习使用Keepalive保证HaProxy的高可用性
2013-11-13 广州项目实施步骤II_练习配置HaProxy的重定向负载均衡