第十九题(最快的方法求Fibonacci数列)

2024-08-29 17:58

本文主要是介绍第十九题(最快的方法求Fibonacci数列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:定义Fibonacci 数列如下:
        /          0                      n=0
f(n)=            1                      n=1
        \    f(n-1)+f(n-2)          n=2

输入n,用最快的方法求该数列的第n 项。


1.采用递归求解,函数的调用过程中,每个函数都都分裂成两个函数,计算的结果没有保存,出现了大量重复计算,算法复杂度O(2^n)

2.采用从下往上的循环结构,时间复杂度O(n)

3.采用矩阵求解,数列中的第n项是矩阵

11

10

n-1次方后所得矩阵的最左上角元素。

因此可以通过矩阵的乘方求解,为了追求更优的时间效率,不采用普通的循环n次乘方的方法,而是采用分治的思想,把n次方换成n/2的平方,以此类推,最终可以达到log(n)的复杂度。

代码:

#include<iostream>
using namespace std;
namespace MS100P_19
{//采用递归的方法,复杂度O(2^n)int Fibonacci_Recursive(int n){if (n == 0)	return 0;if (n == 1)	return 1;else  return Fibonacci_Recursive(n - 1) + Fibonacci_Recursive(n - 2);}//非递归1,时间复杂度 O(n)int Fibonacci_1(int n){long smaller = 0;long bigger = 1;long sum=0;if (n == 0)	return 0;if (n == 1)	return 1;for (int i = 2; i <=n; i++){sum = smaller + bigger;smaller = bigger;bigger = sum;}return bigger;}//非递归,时间复杂度O(logN)struct matrix{long long m00, m01;long long m10, m11;matrix(long long parM00, long long parM01, long long parM10, long long parM11)\:m00(parM00), m01(parM01), m10(parM10), m11(parM11){}matrix() :m00(1), m01(1), m10(1), m11(0){}};matrix matrixMultiply(const matrix& mtx1, const matrix& mtx2){return matrix(mtx1.m00*mtx2.m00 + mtx1.m01*mtx2.m10, mtx1.m00*mtx2.m01 + mtx1.m01*mtx2.m11, \mtx1.m10*mtx2.m00 + mtx1.m11*mtx2.m10, mtx1.m10*mtx2.m01 + mtx1.m11*mtx2.m11);}matrix matrixPower(int power)		//n为指数{matrix temp;if (power == 1)	return temp;if (power % 2 == 0){temp = matrixPower(power / 2);return matrixMultiply(temp, temp);}else{temp = matrixPower(power / 2);temp = matrixMultiply(temp, temp);return matrixMultiply(temp,matrix());}}long long Fibonacci_2(int n){if (n == 0)	return 0;if (n == 1)	return 1;else return matrixPower(n - 1).m00;}void test(){cout << Fibonacci_Recursive(1) << endl;cout << Fibonacci_1(1) << endl;cout << Fibonacci_2(1) << endl;cout << Fibonacci_Recursive(10) << endl;cout << Fibonacci_1(10) << endl;cout << Fibonacci_2(10) << endl;}
}int _tmain(int argc, _TCHAR* argv[])
{MS100P_19::test();return 0;
}



这篇关于第十九题(最快的方法求Fibonacci数列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118571

相关文章

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

Apache Tomcat服务器版本号隐藏的几种方法

《ApacheTomcat服务器版本号隐藏的几种方法》本文主要介绍了ApacheTomcat服务器版本号隐藏的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1. 隐藏HTTP响应头中的Server信息编辑 server.XML 文件2. 修China编程改错误

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

更改docker默认数据目录的方法步骤

《更改docker默认数据目录的方法步骤》本文主要介绍了更改docker默认数据目录的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1.查看docker是否存在并停止该服务2.挂载镜像并安装rsync便于备份3.取消挂载备份和迁

JavaScript DOM操作与事件处理方法

《JavaScriptDOM操作与事件处理方法》本文通过一系列代码片段,详细介绍了如何使用JavaScript进行DOM操作、事件处理、属性操作、内容操作、尺寸和位置获取,以及实现简单的动画效果,涵... 目录前言1. 类名操作代码片段代码解析2. 属性操作代码片段代码解析3. 内容操作代码片段代码解析4.

SpringBoot3集成swagger文档的使用方法

《SpringBoot3集成swagger文档的使用方法》本文介绍了Swagger的诞生背景、主要功能以及如何在SpringBoot3中集成Swagger文档,Swagger可以帮助自动生成API文档... 目录一、前言1. API 文档自动生成2. 交互式 API 测试3. API 设计和开发协作二、使用

python忽略warnings的几种方法

《python忽略warnings的几种方法》本文主要介绍了几种在Python忽略警告信息的方法,,可以使用Python内置的警告控制机制来抑制特定类型的警告,下面就来介绍一下,感兴趣的可以了解一下... 目录方法 1: 使用 warnings 模块过滤特定类型和消息内容的警告方法 2: 使用 warnin