斐波那契数

【题目描述】

小明现在知道斐波那契数列中的第X个数模P后的值N,即Fabonacci(X) mod P = N,以及X可能的最大值M,如果再对于斐波那契数列中每一个数都模P,他想知道这个数可能出现在第几个。

【输入描述】

一行,共3个整数,第一个数为N,第二个数为P,第三个数为X可能的最大值M,三个数以空格隔开。

【输出描述】

一个整数,满足Fabonacci(i) mod P = N的最小的i,如果不存在则输出-1。

【样例输入】

3 7 5

【样例输出】

4

【数据范围及提示】

对于20%的数据,保证0 < M ≤ 50;

对于50%的数据,保证0 < M ≤ 100;

对于70%的数据,保证0 < M ≤ 500;

对于100%的数据,保证0 < M ≤ 1000,0 ≤ N < P,P为素数且2 < P< 105。

源代码:

#include<cstdio>
int m,n,p,f[1001];
bool s(0);
int main() //挺恶心的题。
{
    scanf("%d%d%d",&n,&p,&m);
    f[2]=f[1]=1;
    for (int a=3;a<=m;a++)
    {
        f[a]=(f[a-1]+f[a-2])%p; //Fabonacci数列大约在200左右就会超过int范围。
        if (f[a]==n)
        {
            s=true;
            printf("%d",a);
            break;
        }
    }
    if (n==1) //别忘了f[1]和f[2]。
    {
        s=true;
        printf("1");
    }
    if (!s)
      printf("-1");
    return 0;
}

 

posted @ 2016-06-04 11:48  前前前世。  阅读(562)  评论(0编辑  收藏  举报