C++斐波那契程序
C++ Fibonacci Program
谁能告诉我为什么我会提前得到序列中的一个数字?我似乎找不到问题所在!例如,如果你输入 10,你应该得到 34,但得到 55(前面一个数字,即 11)
#include <iostream>
using namespace std;
int fibonacci (int n);
int main ()
{
int n;
cout << "Fibonacci number generator" << endl;
cout << "Which one do you want (0 to exist)?";
cin >> n;
cout << fibonacci(n);
}
int fibonacci (int n)
{
if (n == 0)
{
return 0;
}
else if (n == 1)
{
return 1;
}
else
{
return (fibonacci(n - 2) + (fibonacci(n - 1)));
}
}
这取决于您如何定义第一个数字。
在您的代码中,它看起来像是从 1 开始的,因此为第 10 个元素输出 55 并没有错。
1, 1, 2, 3, 5, 8, 13, 21, 34, 55
但是,我认为您不小心使它正确,我猜您要做的是:
#include <iostream>
using namespace std;
int fibonacci (int n);
int main () {
int n;
cout<<"Fibonacci number generator"<<endl;
cout<<"Which one do you want (0 to exist)?";
cin>>n;
if(n == 0) {
return 0;
}
cout<<fibonacci(n);
return 0;
}
int fibonacci (int n) {
if (n == 1){
return 0;
} else if (n == 2) {
return 1;
} else {
return (fibonacci(n-2)+(fibonacci(n-1)));
}
}
那是
- 输入为 0 时退出
- 顺序是这样的:
0, 1, 1, 2, 3, 5, 7, 13, 21, 34
斐
波那契数列曾经是:
1, 1, 2, 3, 5, 8, 13, 21, 34, 55
但在现代,它已经演变成:
0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55
请参阅 https://en.wikipedia.org/wiki/Fibonacci_number。
如果使用第一个序列,则种子定义为:
F(1) = 1
F(2) = 1
如果使用第二个序列,则种子定义为:
F(0) = 0
F(1) = 1
只要我们都同意F(10)
是55
,无论是(第一个)序列中的第 10 个数字还是(第二个)序列中的第 11 个数字都没有关系。
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- C++,系统无法执行指定的程序
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 重载操作程序时出错>>用于类中的字符串 memebr
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 试图在visual studio上用C++创建一个桌面应用程序
- 模板元程序查找相似的连续类型名称
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 如何通过cpp程序运行shell脚本
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- IPC使用多个管道和分支进程来运行Python程序
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 基于boost的程序的静态链接——zlib问题
- 程序崩溃并显示"std::out_of_range"错误
- 在C应用程序中运行C++(带有STL)函数
- 使用mongocxx驱动程序时包含头文件问题
- 如何在c++程序中找到函数的地址