0

0

c++怎么实现一个斐波那契数列_c++斐波那契数列实现方法

尼克

尼克

发布时间:2025-10-06 14:32:02

|

696人浏览过

|

来源于php中文网

原创

递归法时间复杂度高,仅适合理解;推荐使用迭代法,时间复杂度O(n)、空间O(1);动态规划通过记忆化避免重复计算,适合多次查询场景。

c++怎么实现一个斐波那契数列_c++斐波那契数列实现方法

实现斐波那契数列在C++中有多种方式,常见的有递归、循环(迭代)和动态规划。每种方法各有特点,适用于不同场景。

1. 递归实现(简单但效率低)

适合理解逻辑,但时间复杂度为 O(2^n),存在大量重复计算。

代码如下:

#include 
using namespace std;

int fib(int n) {
if (n <= 1) return n;
return fib(n - 1) + fib(n - 2);
}

int main() {
int n = 10;
cout << "第 " << n << " 项是:" << fib(n) << endl;
return 0;
}

2. 迭代实现(推荐,效率高)

时间复杂度 O(n),空间复杂度 O(1),适合大数值计算。

使用两个变量保存前两项的值,逐项推进:

立即学习C++免费学习笔记(深入)”;

#include 
using namespace std;

int fib(int n) {
if (n <= 1) return n;
int a = 0, b = 1, c;
for (int i = 2; i <= n; ++i) {
c = a + b;
a = b;
b = c;
}
return b;
}

int main() {
int n = 10;
cout << "第 " << n << " 项是:" << fib(n) << endl;
return 0;
}

用php迭代器来实现一个斐波纳契数列函数类
用php迭代器来实现一个斐波纳契数列函数类

用php迭代器来实现一个斐波纳契数列函数类

下载

3. 动态规划(记忆化递归)

结合递归思想与缓存机制,避免重复计算。

用数组保存已计算的结果:

#include 
using namespace std;

int fibHelper(int n, int* memo) {
if (n <= 1) return n;
if (memo[n] != -1) return memo[n];
memo[n] = fibHelper(n - 1, memo) + fibHelper(n - 2, memo);
return memo[n];
}

int fib(int n) {
int* memo = new int[n + 1];
fill(memo, memo + n + 1, -1); // 初始化为-1
int result = fibHelper(n, memo);
delete[] memo;
return result;
}

int main() {
int n = 10;
cout << "第 " << n << " 项是:" << fib(n) << endl;
return 0;
}

总结: 对于实际应用,推荐使用迭代法,它效率高且不易溢出。递归仅用于教学演示。若需多次查询,可考虑预打表或记忆化优化。

基本上就这些,不复杂但容易忽略性能差异。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

17

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

22

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

91

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

124

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

14

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

65

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

59

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号