热门标签 | 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;
}



推荐阅读
  • 深入探讨栈和队列的应用实例——铁轨问题(Rails, ACM/ICPC CERC 1997, UVa 514)。该问题设定在一个城市火车站,涉及n节车厢从A方向驶入车站,并需按照特定顺序驶出B方向的铁轨。本文将通过算法实现来验证特定顺序的可行性。 ... [详细]
  • Java Set集合源码深度解析
    本文将深入探讨Java集合框架中的Set接口及其主要实现类HashSet、LinkedHashSet和TreeSet的源码实现,帮助读者理解这些集合类的工作原理及应用场景。 ... [详细]
  • socket函数SOCKET()我们使用系统调用socket()来获得文件描述符:#include#includei ... [详细]
  • SQL执行计划解析(2) 基本查询的图形执行计划
    SQL执行计划解析(2)-基本查询的图形执行计划(上)某种程度上,学习阅读图形执行计划和学习一门新语言很类似。 ... [详细]
  • https:www.jianshu.comp2d376a82ba8c?utm_campaignmaleskine&utm_contentnote&utm_mediumseo_not ... [详细]
  • 漫水填充算法是一种基于特定颜色填充连通区域的技术,通过设定像素连通性的阈值和连通模式,可以实现不同的填充效果。该算法广泛应用于图像处理领域,如图像分割、标记特定区域等。 ... [详细]
  • 本文探讨了在C#服务中捕获控制台输出的有效方法,特别是在远程系统部署的应用场景下。文中不仅提供了基础的解决方案,还深入讨论了最佳实践,如使用日志库和事件日志等。 ... [详细]
  • 尽管大多数解决方案倾向于使用递归来解决数独问题,但递归方法并非总是最优选择。本文探讨了一种基于迭代的方法来求解数独,这种方法不仅避免了递归的局限性,还通过使用集合来高效管理空位及其可能的数字选项。此方法未采用剪枝或最小候选数优先策略,而是通过迭代遍历所有可能性来寻找解。 ... [详细]
  • JSP与MySQL集成:实现数据添加与查询功能
    本文介绍了如何使用JSP和MySQL数据库来实现基本的数据添加和查询功能,包括数据库的准备、JSP页面的编写以及数据操作的具体步骤。 ... [详细]
  • 尽管大多数递归函数能够通过循环和栈结构重写,但在某些特定条件下,这种转换变得极为复杂甚至不可能。本文探讨了这些条件及其背后的原理。 ... [详细]
  • 本教程将指导您完成 Spring Boot 应用程序中 MySQL 数据库的配置,并通过 JdbcTemplate 进行基本的数据操作测试。在此之前,我们已经成功打包并测试了 jar 和 war 包,同时实现了 JSP 页面的访问,但页面数据是静态配置的。现在,让我们一起进入数据库配置的世界。 ... [详细]
  • 本文详细介绍了如何在Mac操作系统中利用Java编程语言执行Android Debug Bridge (ADB) 的'devices'命令,以获取连接到系统的Android设备列表。 ... [详细]
  • 文章目录17、less17-UpdateQuery-Errorbased-String18、less18-HeaderInjection-ErrorBased-string19、l ... [详细]
  • 开发笔记:图像分割基于阙值+边缘检测+区域法图像分割matlab源码含GUI
    开发笔记:图像分割基于阙值+边缘检测+区域法图像分割matlab源码含GUI ... [详细]
  • 本文详细探讨了一道涉及算法、C++及图论知识点的题目,适合对算法竞赛感兴趣的读者。通过分析题目【这是一道大水题】,我们将探索如何高效地处理区间查询与更新问题。本文由技术作者【ღCauchyོꦿ࿐】撰写,旨在帮助读者掌握相关技术和解题技巧。 ... [详细]
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社区 版权所有