快速幂取模
来源:互联网 发布:linux 发送arp包 编辑:程序博客网 时间:2024/05/21 17:32
在平常的练习中,我们经常需要求a的b次幂模p的结果。这次就专门讲讲这个。
之前,b的规模不是很大。所以我们都是这样做的:
for(int i = 1; i <= b; i++) ans *= a, ans %= p;
然而,当b很大时,如10^9时,这种方法就大大滴超时了。。。
为了搞定b较大时的幂取模运算,在这里提一下快速幂取模的方法。
以27^11为例:
1、将11转化为二进制得:1011
2、则原式可转换为:27^(2^3)*27^(2^1)*27(2^0)......(同底数幂的计算)
但感觉这里的27^(2^n)还是很难算。。。还是先看看代码实现吧。
int h = a;while(b){ if(b & 1) ans *= h, ans %= p; h*= h, h %= p, b >>= 1;}
看到这一小段程序的变量h。它就完美地实现了求a^(2^n)的过程(a^n*a^n=a^(2^n) (n≠0))
阅读全文
0 0
- 快速幂,快速幂取模
- 快速幂 + 快速幂取模
- 快速幂 快速幂取模
- 快速幂 快速幂取模
- 【快速幂】【快速幂取模】
- 快速幂,快速幂取模,矩阵快速幂
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 第二天
- spring+mybatis出现 An attempt by a client to checkout a Connection has timed out
- fragement的循环添加
- 2017-7-11 ie浏览器的问题
- ThinkPHP多字段匹配模糊查询
- 快速幂取模
- 对OpenGLES中VBO与VAO的理解
- Codeforces 193B
- xcode编译代码到非测试机
- HashMap简单分析
- python的对象
- WebSocket实现Android客户端之间的简单通讯
- @Table
- qml与C++的交互