uva 10229 - Modular Fibonacci(矩阵快速幂)
来源:互联网 发布:fda医疗器械数据库 编辑:程序博客网 时间:2024/04/28 04:29
题目链接:uva 10229 - Modular Fibonacci
题目大意:给出n和m,求出f(n) %m, f(x)为斐波那契数列。
解题思路:因为n的范围在0~214783647,所以计算量比较大,所以用矩阵快速幂。
{(1, 1), (1, 0)} ^ n *(f[1], f[0]) = (f[n], f[n - 1]).
#include <stdio.h>#include <math.h>long long n, b, k;struct state {long long s[2][2];state(long long a = 0, long long b = 0, long long c = 0, long long d = 0) {s[0][0] = a, s[0][1] = b, s[1][0] = c, s[1][1] = d;}}tmp(1, 0, 0, 1), c(1, 1, 1, 0);state count(const state& p, const state& q) {state f;for (int i = 0; i < 2; i++)for (int j = 0; j < 2; j++)f.s[i][j] = (p.s[i][0] * q.s[0][j] + p.s[i][1] * q.s[1][j]) % b;return f;}state solve(long long k) {if (k == 0) return tmp;else if (k == 1) return c;state a = solve(k / 2);a = count(a, a);if (k % 2) a = count(a, c);return a;}int main () {int m;while (scanf("%lld%d", &n, &m) == 2) {b = pow(2, m);if (n) {state ans = solve(n - 1);k = ans.s[0][0];} elsek = 0;printf("%lld\n", k);}return 0;}
- UVA - 10229 - Modular Fibonacci (矩阵快速幂 + fibonacci)
- uva 10229 - Modular Fibonacci(矩阵快速幂)
- UVA 10229 Modular Fibonacci (矩阵乘法+快速幂)
- UVa 10229 Modular Fibonacci (矩阵快速幂求斐波那契)
- UVA 10229 Modular Fibonacci
- UVA - 10229 Modular Fibonacci
- UVa:10229 Modular Fibonacci
- uva 10229 - Modular Fibonacci
- UVa 10229 - Modular Fibonacci
- uva 10229Modular Fibonacci
- UVa 10229 - Modular Fibonacci(数论,规律)
- 10299 Problem A: Modular Fibonacci(斐波那契的矩阵快速幂)
- UVA10299- Modular Fibonacci(斐波那契数列+矩阵快速幂)
- Fibonacci(矩阵快速幂)
- 【矩阵快速幂】Fibonacci
- Fibonacci 矩阵快速幂
- Fibonacci 矩阵快速幂
- Fibonacci (矩阵快速幂)
- A与B 之间最长的子串
- java泛型之四——上下限
- VC打开制定文件夹
- android4.0.3去掉底部状态栏statusbar,全屏显示示例代码
- jbpm4.4整合spring2.5
- uva 10229 - Modular Fibonacci(矩阵快速幂)
- UVA 991 Safe Salutations
- 如何在vs2010中设置C++ main 函数的实参int main(int argc ,char *argv[])
- "半连接"检测的研究
- C语言交换a和b的值
- 模板卷积Template Convolution
- XCode的文件组织
- 互联网广告的RTB革命
- web.xml中load-on-startup的作用