蓝桥杯 参考题目 黄金队列(水题)

  黄金分割数0.618与美学有重要的关系。舞台上报幕员所站的位置大约就是舞台宽度的0.618处,墙上的画像一般也挂在房间高度的0.618处,甚至股票的波动据说也能找到0.618的影子....

  黄金分割数是个无理数,也就是无法表示为两个整数的比值。0.618只是它的近似值,其真值可以通过对5开方减去1再除以2来获得,我们取它的一个较精确的近似值:0.618034

  有趣的是,一些简单的数列中也会包含这个无理数,这很令数学家震惊!

  1 3 4 7 11 18 29 47 .... 称为“鲁卡斯队列”。它后面的每一个项都是前边两项的和。

  如果观察前后两项的比值,即:1/3,3/4,4/7,7/11,11/18 ... 会发现它越来越接近于黄金分割数!

  你的任务就是计算出从哪一项开始,这个比值四舍五入后已经达到了与0.618034一致的精度。

  请写出该比值。格式是:分子/分母。比如:29/47

  答案写在“解答.txt”中,不要写在这里!


 

  水题。

  求斐波那契数列+模拟除法。

  解答:1364/2207

 1 #include <iostream>
 2 using namespace std;
 3 unsigned long long f[1000];
 4 int main()
 5 {
 6     f[1]=1;
 7     f[2]=3;
 8     int i;
 9     for(i=3;f[i-1]<1e18;i++){
10         f[i] = f[i-1] + f[i-2];
11     }
12     cout<<i<<endl;
13     i--;
14     for(int i=3;i<30;i++){
15         unsigned long long x = f[i-2];
16         unsigned long long y = f[i-1];
17         cout<<x<<' '<<y<<endl;
18         for(int j=0;j<=20;j++){
19             cout<<x/y;
20             x = (x%y)*10;
21             if(j==0)
22                 cout<<'.';
23             if(j%10==0)
24                 cout<<' ';
25         }
26         cout<<endl;
27     }
28     return 0;
29 }

 

Freecode : www.cnblogs.com/yym2013

原文地址:https://www.cnblogs.com/yym2013/p/3608763.html