目录
斐波纳契数之组合

** 斐波纳契数之组合:** <Excerpt in index | 首页摘要>

<The rest of contents | 余下全文>

斐波纳契数之组合
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-2(n>=2),对于每一项,它们都是斐波那契数。

现在给出一个整数d,求一个组合使得a + b + c = d,其中a、b、c 都是斐波纳契数,且a <= b <= c。
Input
有多组测试数据,对于每组测试数据,仅包含一个整数d(0<=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

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#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;
}
文章作者: 爱笑的k11
文章链接: http://1315402725.github.io/posts/e11756c2/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 爱笑的k11
打赏
  • 微信
  • 支付寶

评论