博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA 11582 巨大的斐波那契额数列! 快速幂取模
阅读量:5815 次
发布时间:2019-06-18

本文共 1083 字,大约阅读时间需要 3 分钟。

从现在开始做紫皮书上的题, 本题是一道斐波那契数列的题, 结合快速幂, 水题。

输入a, b, n, 计算f( a ^ b) % n  , f( i ) = f( i - 1) + f( i - 2 ) , f( 0 ) = f(1) = 1, 其中,0 <= a , b <= 2 ^ 64,  0 <= n <= 1000

以后少废话, 直接存代码

// 计算 f(a^b) mod n, 其中 f(i) = f(i-1) + f(i-2), f(0) = f(1) = 1, 其中0 <= a, b < 2^64 , n <= 1000#include 
#include
#include
#include
using namespace std;#define MAXN 1007typedef unsigned long long LL;int f[MAXN*MAXN];int fun( LL a, LL b, int n ) { LL ans = 1; a = a % n; while( b > 0 ) { if( b & 1 ) ans = ans * a % n; b /= 2; a = a * a % n; } return (int)ans;}int main() { LL a, b; int n; int t; cin >> t; while( t-- ) { cin >> a >> b >> n; memset( f, 0, sizeof(f) ); f[0] = f[1] = 1; int i = 0; for( i = 2; i <= n * n; i++ ) { f[i] = ( f[i-1] % n + f[i-2] % n ) % n; } cout << f[fun( a, b, n )-1] << endl; } }
View Code

 

转载于:https://www.cnblogs.com/FriskyPuppy/p/6552761.html

你可能感兴趣的文章
安卓中数据库的搭建与使用
查看>>
AT3908 Two Integers
查看>>
渐变色文字
查看>>
C++ 0X 新特性实例(比较常用的) (转)
查看>>
node生成自定义命令(yargs/commander)
查看>>
各种非算法模板
查看>>
node-express项目的搭建并通过mongoose操作MongoDB实现增删改查分页排序(四)
查看>>
PIE.NET-SDK插件式二次开发文档
查看>>
如何创建Servlet
查看>>
.NET 设计规范--.NET约定、惯用法与模式-2.框架设计基础
查看>>
win7 64位+Oracle 11g 64位下使用 PL/SQL Developer 的解决办法
查看>>
BZOJ1997:[HNOI2010]PLANAR——题解
查看>>
BZOJ1014:[JSOI2008]火星人prefix——题解
查看>>
使用Unity3D引擎开发赛车游戏
查看>>
HTML5新手入门指南
查看>>
构建NetCore应用框架之实战篇系列
查看>>
淘宝NPM镜像cnpm
查看>>
01-构造和运行模块
查看>>
opennebula 开发记录
查看>>
knockoutjs 之 subscribe 的小分享
查看>>