UVa11582 - Colossal Fibonacci Numbers!(模运算)

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<stack>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<algorithm>
using namespace std;
typedef unsigned long long ULL;

const int maxn = 1005;
int f[maxn][6*maxn],p[maxn];

int pow_mod(ULL a,ULL b,int n){
    if(b==0) return 1;
    int k=pow_mod(a,b/2,n);
    k=k*k%n;
    if(b%2==1) k=k*a%n;
    return k;
}

int solve(ULL a,ULL b,int n){
    if(a==0||n==1) return 0;
    int idx=pow_mod(a%p[n],b,p[n]);
    return f[n][idx];
}
int main()
{
    int ncase;
    int n;
    for(int n=2;n<=1000;n++){
        f[n][0]=0; f[n][1]=1;
        for(int i=2;;i++){
            f[n][i]=(f[n][i-2]+f[n][i-1])%n;
            if(f[n][i-1]==0&&f[n][i]==1){
                p[n]=i-1;
                break;
            }
        }
    }
    scanf("%d",&ncase);
    while(ncase--){
        ULL a,b;

        cin>>a>>b>>n;
        cout<<solve(a,b,n)<<"\n";
    }
    return 0;
}

时间: 2024-08-25 02:51:32

UVa11582 - Colossal Fibonacci Numbers!(模运算)的相关文章

UVA11582 Colossal Fibonacci Numbers!(fibonacci序列模x的周期性)

题意:两个非负整数a,b<2^64 计算斐波拉契序列f(a^b)mod x  (x<1000) 思路:显然a^b只能用快速幂,而且还必须要取模,所以去尝试找f(n)mod x的周期 不能发现当二元组(f[i]%x,fp[i-1]%x)=(f[0]%x,f[1]%x) 的时候开始循环,所以周期为i 因为f[n]%x的余数最多只有1000种所以在f[0...n^2]以内就能找到周期 <span style="font-size:14px;">// Accepted

UVa11582 Colossal Fibonacci Numbers!

1 #include<cstdio> 2 #include<iostream> 3 #include<cstring> 4 #include<algorithm> 5 using namespace std; 6 const int maxn = 10005; //如果是1005就会RE,当不确定时,最好取大点. 7 int A[maxn]; 8 #define LL unsigned long long // 注意不能用long long, 因为long

uva11582 Colossal Fibonacci Numbers(分治法)

题意:输入两个非负整数a.b和正整数n(a,b>=0&&a,b<2^64,n>=1&&n<=1000),你的任务是计算f(a^b)除以n的余数.其中f(0)=f(1),且对于所有非负整数i,f(i+2)=f(i+1)+f(i) 解题思路:设F(i)=f(i) mod n.不难发现当(F(i),F(i+1))重复出现时,整个序列就开始重复.所以我们需要找到对于不同的n重复周期,因为余数有n中,所以最多n^2项就会出现重复(其实我们也可以通过打表观察,在

UVA 11582 Colossal Fibonacci Numbers! 数学

n比较小,最多n*n就回出现循环节.... Colossal Fibonacci Numbers! Time Limit: 1000MS   Memory Limit: Unknown   64bit IO Format: %lld & %llu Submit Status Description Problem F: Colossal Fibonacci Numbers! The i'th Fibonacci number f (i) is recursively defined in the

UVA 11582 Colossal Fibonacci Numbers!(打表+快速幂)

Colossal Fibonacci Numbers! The i'th Fibonacci number f (i) is recursively defined in the following way: f (0) = 0 and f (1) = 1 f (i+2) = f (i+1) + f (i)  for every i ≥ 0 Your task is to compute some values of this sequence. Input begins with an int

UVA 11582 Colossal Fibonacci Numbers! 找循环节

注意n=1的情况 #include <cstdio> #include <cstring> #include <cmath> #include <algorithm> #include <climits> #include <string> #include <iostream> #include <map> #include <cstdlib> #include <list> #inc

UVA 11582 Colossal Fibonacci Numbers!(循环节打表+幂取模)

题目链接:https://cn.vjudge.net/problem/UVA-11582 1 /* 2 问题 3 输入a,b,n(0<a,b<2^64(a and bwill not both be zero) and 1<n<1000) 4 计算并输出f(a^b)%n的结果 5 其中f(i)是斐波那契数列 6 7 解题思路 8 所有的结果都是f(i)对n取模,不妨设F(i)=f(i)%n.不难发现当F(i),F(i+1)出现重复的时候,整个序列就开始出现重复. 9 10 所以设周

UVa 11582 Colossal Fibonacci Numbers! 【大数幂取模】

题目链接:Uva 11582 [vjudge] 题意 输入两个非负整数a.b和正整数n(0<=a,b<=2^64,1<=n<=1000),让你计算f(a^b)对n取模的值,当中f(0) = 0,f(1) =  1.且对随意非负整数i.f(i+2)= f(i+1)+f(i). 分析 全部的计算都是对n取模.设F(i) =f(i)mod n, 非常easy发现,F(x)是具有周期性的,由于对N取模的值最多也就N个,当二元组(F(i-1),F(i))反复的时候.整个序列也就反复了.周期i

UVA 11582 - Colossal Fibonacci Numbers!(数论)(分治法幂取模)

巨大的斐波那契数! 题目大意:斐波那契数列f[N],给你a,b,n,求f[a^b]%n. 思路:数论题.f[a^b]%n是有周期的,我们求出来这个周期后就可以将简化成f[(a%周期)^b]%周期运用分治法幂取模. 注意用unsigned long long(貌似是 long long的二倍),不然会溢出,又学了一招... 不知道哪的bug,一直改不对,一直,后来捡来别人的和自己一样的代码一改就对了,,, #include<iostream>//UVA #include<cstdio>