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


推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • C++: 实现基于类的四面体体积计算
    本文介绍如何使用C++编程语言,通过定义类和方法来计算由四个三维坐标点构成的四面体体积。文中详细解释了四面体体积的数学公式,并提供了两种不同的实现方式。 ... [详细]
  • 本文探讨了如何在模运算下高效计算组合数C(n, m),并详细介绍了乘法逆元的应用。通过扩展欧几里得算法求解乘法逆元,从而实现除法取余的计算。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
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社区 版权所有