快速幂取模
来源:互联网 发布:国产手机推荐 知乎 编辑:程序博客网 时间:2024/04/29 08:39
int powermod(int a,int b,int c) { int ans=1; while(b) { if(b&1) //b是奇数,即二进制最后一位为1 ans=(ans*a)%c; a=(a*a)%c; //权值不断开方,同时可以模c无影响 b=b>>1; //不断右移除2 } return ans; }
矩阵快速幂
//HOJ 3493/*===================================*/|| 快速幂(quickpow)模板 || P 为等比,I 为单位矩阵|| MAX 要初始化!!!!||/*===================================*//*****************************************************/#include <cstdio>const int MAX = 3;typedef struct{ int m[MAX][MAX];} Matrix;Matrix P = {5,-7,4, 1,0,0, 0,1,0, };Matrix I = {1,0,0, 0,1,0, 0,0,1, }; Matrix matrixmul(Matrix a,Matrix b) //矩阵乘法{ int i,j,k; Matrix c; for (i = 0 ; i < MAX; i++) for (j = 0; j < MAX;j++) { c.m[i][j] = 0; for (k = 0; k < MAX; k++) c.m[i][j] += (a.m[i][k] * b.m[k][j])%9997; c.m[i][j] %= 9997; } return c;} Matrix quickpow(long long n){ Matrix m = P, b = I; while (n >= 1) { if (n & 1) b = matrixmul(b,m); n = n >> 1; m = matrixmul(m,m); } return b;} /*************************************/int main(){ Matrix re; int f[3] = {2,6,19}; long long n; while (scanf("%I64d",&n) && n != 0) { if (n == 1) printf("1\n"); else if (n <= 4) printf("%d\n",f[n-2]); else { re = quickpow(n - 4); printf("%d\n",(((re.m[0][0]*f[2]) + (re.m[0][1]*f[1]) + (re.m[0][2]*f[0])) %9997 + 9997) % 9997); } } return 0;}
0 0
- 快速幂,快速幂取模
- 快速幂 + 快速幂取模
- 快速幂 快速幂取模
- 快速幂 快速幂取模
- 【快速幂】【快速幂取模】
- 快速幂,快速幂取模,矩阵快速幂
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- 快速幂取模
- tableView的一些方法
- JavaScript中按照字母排序列表的两种方法
- 普林斯顿公开课 算法1-1:算法分析
- 关于HAProxy的listen与等价的backend
- Android智能指针分析(sp、wp)
- 快速幂取模
- IOS中GET和POST请求方式的差异
- 设计模式------工厂三姐妹
- 普林斯顿公开课 算法1-2:观察
- query 中出口变量的增强
- Linux启动时 Error 15: File not found 问题解决方法
- XML和JSON解析
- OGG 机器重起后挂起,无明显报错信息
- 普林斯顿公开课 算法1-3:数学模型