斐波那契数列前50项函数c语言
时间: 2023-11-26 08:48:23 浏览: 128
以下是C语言中求斐波那契数列前50项的函数:
```c
#include <stdio.h>
long long fibonacci(int n) {
if (n == 1 || n == 2) {
return 1;
} else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
int main() {
int n = 50;
long long sum = 0;
for (int i = 1; i <= n; i++) {
printf("%lld ", fibonacci(i));
sum += fibonacci(i);
}
printf("\n斐波那契数列前50项的和为:%lld\n", sum);
return 0;
}
```
该函数使用递归的方式计算斐波那契数列的第n项,然后在主函数中循环调用该函数,输出前50项的值,并计算它们的和。
相关问题
用c语言递归函数写出斐波那契数列前十项
以下是使用递归函数在 C 语言中编写斐波那契数列前十项的代码:
```c
#include <stdio.h>
int fibonacci(int n) {
if (n <= 1) {
return n;
}
return fibonacci(n-1) + fibonacci(n-2);
}
int main() {
int n = 10; // 前十项
// 输出前十项
for (int i = 0; i < n; i++) {
printf("%d ", fibonacci(i));
}
return 0;
}
```
运行以上代码,将会输出斐波那契数列的前十项:
```
0 1 1 2 3 5 8 13 21 34
```
在代码中,我们定义了一个递归函数 `fibonacci`,它接受一个整数 `n` 作为参数,并返回斐波那契数列的第 `n` 项。如果 `n` 小于等于 1,则直接返回 `n`。否则,递归地调用函数 `fibonacci(n-1)` 和 `fibonacci(n-2)`,然后将它们的结果相加返回。
在 `main` 函数中,我们使用一个循环调用 `fibonacci` 函数来输出斐波那契数列的前十项。每次循环,我们将当前的索引值作为参数传递给 `fibonacci` 函数,并将结果打印出来。
用递归写斐波那契数列第n项的c语言程序
好的,以下是使用递归实现斐波那契数列第n项的C语言程序:
```c
#include <stdio.h>
int fibonacci(int n) {
if (n <= 1) {
return n;
} else {
return fibonacci(n-1) + fibonacci(n-2);
}
}
int main() {
int n;
printf("请输入要计算第几项的斐波那契数列:");
scanf("%d", &n);
printf("斐波那契数列第%d项的值为:%d", n, fibonacci(n));
return 0;
}
```
在这个程序中,我们定义了一个 `fibonacci` 函数,该函数使用递归来计算斐波那契数列的第n项。我们首先检查输入的数字 `n` 是否小于等于 1。如果是,我们直接返回 `n`。如果不是,我们使用递归来计算前两个数的和,并返回结果。在 `main` 函数中,我们通过调用 `fibonacci` 函数来计算斐波那契数列的第n项,并将结果输出到屏幕上。