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

九度编程挑战:斐波那契数列的高效算法解析

本文详细解析了九度编程平台上的斐波那契数列高效算法挑战(题目编号:1387)。该挑战要求在1秒的时间限制和32兆的内存限制下,设计出高效的斐波那契数列计算方法。通过多种算法的对比和性能分析,本文提供了优化方案,帮助参赛者在限定资源条件下实现高效计算。

题目来源:http://ac.jobdu.com/problem.php?pid=1387

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:3859

解决:1159

题目描述:

大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。斐波那契数列的定义如下:

输入:

输入可能包含多个测试样例,对于每个测试案例,

输入包括一个整数n(1<=n<=70)。

输出:

对应每个测试案例,

输出第n项斐波那契数列的值。

样例输入:
3
样例输出:
2
#include 
#include
#include

using namespace std;

typedef long long LL;

LL Fab(int n)
{
LL a[2] = {0, 1}, i;
if(n <2)
return a[n];
for(i = 2; i <= n; ++i)
a[i%2] = a[(i-1)%2] + a[(i-2)%2];
return a[n%2];
}

int main()
{
int n;
while(~scanf("%d", &n))
printf("%lld\n", Fab(n));
return 0;
}

解法二:

学过高数的同学,我们都知道斐波那契数列的递推公式可以写成如下形式:


如此,我们只要求出等式右边矩阵的n-1幂,就可以求出f(n)。

求矩阵的n-1次幂,可以借助快速幂来求解。

#include 
#include
#include

typedef long long LL;

struct Matrix
{
LL iMatrix[2][2];
};

Matrix iPer, iCell;

void Inite()
{
for(int i = 0; i <2; ++i)
{
for(int j = 0; j <2; ++j)
{
iPer.iMatrix[i][j] = (i == j);
iCell.iMatrix[i][j] = 1;
}
}
iCell.iMatrix[1][1] = 0;
}

Matrix Multi_Matrix(Matrix a, Matrix b)
{
Matrix c;
for(int i = 0; i <2; ++i)
{
for(int j = 0; j <2; ++j)
{
c.iMatrix[i][j] = 0;
for(int k = 0; k <2; ++k)
c.iMatrix[i][j] += a.iMatrix[i][k] * b.iMatrix[k][j];
}
}
return c;
}

Matrix Quick_Mod(int k)
{
if(k == 1)
return iCell;
Matrix c = iPer;
Matrix b = iCell;
while(k)
{
if(k & 1)
{
c = Multi_Matrix(c, b);
k--;
}
b = Multi_Matrix(b, b);
k >>= 1;
}
return c;
}

int main()
{
int n;
Matrix c;
Inite();
while(~scanf("%d", &n))
{
if(n == 0)
{
printf("0\n");
continue;
}
c = Quick_Mod(n-1);
printf("%lld\n", c.iMatrix[0][0]);
}
return 0;
}



推荐阅读
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 深入解析Spring启动过程
    本文详细介绍了Spring框架的启动流程,帮助开发者理解其内部机制。通过具体示例和代码片段,解释了Bean定义、工厂类、读取器以及条件评估等关键概念,使读者能够更全面地掌握Spring的初始化过程。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 本文介绍如何利用栈数据结构在C++中判断字符串中的括号是否匹配。通过顺序栈和链栈两种方式实现,并详细解释了算法的核心思想和具体实现步骤。 ... [详细]
  • 使用Nginx反向代理实现多域名端口映射
    本文介绍如何通过配置本地hosts文件和Nginx反向代理,实现多个虚拟域名的端口映射,使用户可以通过标准HTTP端口80访问不同后端服务。 ... [详细]
  • 历经三十年的开发,Mathematica 已成为技术计算领域的标杆,为全球的技术创新者、教育工作者、学生及其他用户提供了一个领先的计算平台。最新版本 Mathematica 12.3.1 增加了多项核心语言、数学计算、可视化和图形处理的新功能。 ... [详细]
  • Linux环境下C语言实现定时向文件写入当前时间
    本文介绍如何在Linux系统中使用C语言编程,实现在每秒钟向指定文件中写入当前时间戳。通过此示例,读者可以了解基本的文件操作、时间处理以及循环控制。 ... [详细]
  • 使用PHP实现网站访客计数器的完整指南
    本文详细介绍了如何利用PHP构建一个简易的网站访客统计系统。通过具体的代码示例和详细的解释,帮助开发者理解和实现这一功能,适用于初学者和有一定经验的开发人员。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 主板IO用W83627THG,用VC如何取得CPU温度,系统温度,CPU风扇转速,VBat的电压. ... [详细]
  • 本文介绍了如何使用JavaScript的Fetch API与Express服务器进行交互,涵盖了GET、POST、PUT和DELETE请求的实现,并展示了如何处理JSON响应。 ... [详细]
  • 本文探讨了如何在 F# Interactive (FSI) 中通过 AddPrinter 和 AddPrintTransformer 方法自定义类型(尤其是集合类型)的输出格式,提供了详细的指南和示例代码。 ... [详细]
  • 本文总结了优化代码可读性的核心原则与技巧,通过合理的变量命名、函数和对象的结构化组织,以及遵循一致性等方法,帮助开发者编写更易读、维护性更高的代码。 ... [详细]
  • 本文介绍两道有趣的编程问题:一是寻找给定数字n的连续数字序列及其个数,二是模拟一个翻杯子的游戏。同时附带一道智商题供读者思考。 ... [详细]
author-avatar
互联网控军
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有