斐波纳契数之组合
Time Limit: 1000 MS Memory Limit: 65535 K
Total Submit: 145(66 users) Total Accepted: 83(65 users) Rating: Special Judge: No
Description

斐波那契数列是这么定义的:F0 = 1, F1 = 1, F2 = F1 + F0,··· Fn = Fn-1 + Fn-2n>=2),对于每一项,它们都是斐波那契数。

现在给出一个整数d,求一个组合使得a + b + c = d,其中abc 都是斐波纳契数,且a <= b <= c
Input

有多组测试数据,对于每组测试数据,仅包含一个整数d0<=d<=2000000000)。

处理到文件结束,测试数据组数少于150组。

Output

对于每组测试数据,输出一行,如果存在 a b c ,则输出最小字典序的组合,否则输出-1

Sample Input
3
4
5
0
Sample Output
1 1 1
1 1 2
1 1 3
-1
Source
计算机科学与技术学院2012级新生程序设计竞赛(正式赛)
Author
黄李龙@HRBUST

 

#include<iostream>
#include<algorithm>
#include<cmath>
using namespace std;
typedef long  LONG;
int main()
{
    LONG a[48];
    a[0]=0;
    a[1]=1;
    int i;
    for(i=2;i<=47;i++)
    {
        a[i]=a[i-1]+a[i-2];
    }
    LONG d;
    while(~scanf("%ld",&d))
    {
        int j,k;
        int key=0;
        for(i=1;i<=47;i++)
        {
            for(j=1;j<=47;j++)
            {
                for(k=1;k<=47;k++)
                {
                    if(a[i]+a[j]+a[k]==d)
                    {
                        key=1;
                        printf("%ld %ld %ld\n",a[i],a[j],a[k]);
                        break;
                    }
                }
                if(key)
                {
                    break;
                }
            }
            if(key)
            {
                break;
            }
        }
        if(!key)
        {
            printf("-1\n");
        }
    }
    return 0;
}