C言語でフィボナッチ数列の先頭からn個の値を求める方法
C言語では、ループか再帰を使ってフィボナッチ数列の先頭n項の値を求めることができます。
- 繰り返しを使用して
#include <stdio.h>
void fibonacci(int n) {
int i, t1 = 0, t2 = 1, nextTerm;
printf("斐波那契数列的前 %d 项为:\n", n);
for (i = 1; i <= n; i++) {
printf("%d, ", t1);
nextTerm = t1 + t2;
t1 = t2;
t2 = nextTerm;
}
}
int main() {
int n;
printf("请输入斐波那契数列的项数:");
scanf("%d", &n);
fibonacci(n);
return 0;
}
- 再帰的に
#include <stdio.h>
int fibonacci(int n) {
if (n == 0 || n == 1) {
return n;
}
return fibonacci(n - 1) + fibonacci(n - 2);
}
int main() {
int n, i;
printf("请输入斐波那契数列的项数:");
scanf("%d", &n);
printf("斐波那契数列的前 %d 项为:\n", n);
for (i = 0; i < n; i++) {
printf("%d, ", fibonacci(i));
}
return 0;
}
どちらの方法でもフィボナッチ数列の最初の n 項を求めますが、通常はループを使用したほうが効率的です。しかし、再帰を使用したほうがより簡潔です。