热门标签 | 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值。


推荐阅读
  • 本题要求在一组数中反复取出两个数相加,并将结果放回数组中,最终求出最小的总加法代价。这是一个经典的哈夫曼编码问题,利用贪心算法可以有效地解决。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • CSS高级技巧:动态高亮当前页面导航
    本文介绍了如何使用CSS实现网站导航栏中当前页面的高亮显示,提升用户体验。通过为每个页面的body元素添加特定ID,并结合导航项的类名,可以轻松实现这一功能。 ... [详细]
  • 本文介绍两道有趣的编程问题:一是寻找给定数字n的连续数字序列及其个数,二是模拟一个翻杯子的游戏。同时附带一道智商题供读者思考。 ... [详细]
  • 深入解析Spring启动过程
    本文详细介绍了Spring框架的启动流程,帮助开发者理解其内部机制。通过具体示例和代码片段,解释了Bean定义、工厂类、读取器以及条件评估等关键概念,使读者能够更全面地掌握Spring的初始化过程。 ... [详细]
  • 本文介绍了如何使用暴力方法解决HDU5444问题。代码通过逐个检查输入数据,确保在所有情况下都能找到正确的解决方案。 ... [详细]
  • 在编译BSP包过程中,遇到了一个与 'gets' 函数相关的编译错误。该问题通常发生在较新的编译环境中,由于 'gets' 函数已被弃用并视为安全漏洞。本文将详细介绍如何通过修改源代码和配置文件来解决这一问题。 ... [详细]
  • 本文介绍了一种基于选择排序思想的高效排序方法——堆排序。通过使用堆数据结构,堆排序能够在每次查找最大元素时显著提高效率。文章详细描述了堆排序的工作原理,并提供了完整的C语言代码实现。 ... [详细]
  • Linux环境下进程间通信:深入解析信号机制
    本文详细探讨了Linux系统中信号的生命周期,从信号生成到处理函数执行完毕的全过程,并介绍了信号编程中的注意事项和常见应用实例。通过分析信号在进程中的注册、注销及处理过程,帮助读者理解如何高效利用信号进行进程间通信。 ... [详细]
  • 探讨ChatGPT在法律和版权方面的潜在风险及影响,分析其作为内容创造工具的合法性和合规性。 ... [详细]
  • 本文探讨了符号三角形问题,该问题涉及由相同数量的“+”和“-”符号组成的三角形。通过递归回溯法,可以有效地搜索并计算符合条件的符号三角形的数量。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • InmyapplicationIhaveQGraphicsScenewithpixmapaddedandallisviewedinQGraphicsViewwithsc ... [详细]
  • 二叉树的链表实现
    本文介绍了一种使用链表结构表示二叉树的方法。通过定义节点结构和相关操作函数,可以方便地创建、插入和遍历二叉树。 ... [详细]
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
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社区 版权所有