热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

蓝桥杯竞赛:Fibonacci数列与黄金比例

Fibonacci数列是一个广为人知的数学序列,其定义为:F(1)=1,F(2)=1,对于i>2,F(i)=F(i-1)+F(i-2)。本题将探讨Fibonacci数列中相邻项的比值如何趋近于黄金比例,并通过编程实现这一性质的验证。

问题描述

Fibonacci数列是一个经典的数学序列,定义如下:F(1) = 1, F(2) = 1,对于i > 2,F(i) = F(i-1) + F(i-2)。Fibonacci数列有一个有趣的性质,即前一项与后一项的比值F(i) / F(i+1)会逐渐趋近于黄金比例(约为1.6180339887)。为了验证这一性质,给定一个正整数N (1 ≤ N ≤ 2000000000),计算F(N) / F(N+1),并保留8位小数。

输入格式

输入一个正整数N。

输出格式

输出F(N) / F(N+1),保留8位小数。

样例输入

2

样例输出

0.50000000

源代码

#include 
int dp[1000];

// 递归求斐波那契数
int Fibonacci_recursive(int N) {
    if (N == 1 || N == 2) return 1;
    else return Fibonacci_recursive(N - 1) + Fibonacci_recursive(N - 2);
}

// 动态规划求斐波那契数
int Fibonacci_dp(int N) {
    dp[1] = dp[2] = 1;
    for (int i = 3; i <= N; i++) {
        dp[i] = dp[i - 1] + dp[i - 2];
    }
    return dp[N];
}

void calculate_golden_ratio() {
    int N;
    double ratio;
    printf("Fibonacci数列与黄金比例\n");
    printf("请输入正整数N: ");
    scanf("%d", &N);

    int fib_N, fib_N_plus_1;
    if (N >= 20) {
        fib_N = Fibonacci_dp(20);
        fib_N_plus_1 = Fibonacci_dp(21);
    } else {
        fib_N = Fibonacci_dp(N);
        fib_N_plus_1 = Fibonacci_dp(N + 1);
    }

    ratio = (double)fib_N / fib_N_plus_1;
    printf("黄金比例的结果为: %.8lf\n", ratio);
}

int main() {
    calculate_golden_ratio();
    return 0;
}

运行结果

运行结果截图

解题思路

当N非常大时,直接计算Fibonacci数会导致数据溢出。因此,可以通过预先计算并存储较小范围内的Fibonacci数,然后利用这些预计算的值来解决大N的情况。通过实验发现,当N ≥ 20时,保留8位小数的结果基本一致,因此可以直接使用N = 20时的结果来处理更大的N值。


推荐阅读
author-avatar
军魂永驻1971
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有