C言語でフィボナッチ数列の先頭からn個の値を求める方法

C言語では、ループか再帰を使ってフィボナッチ数列の先頭n項の値を求めることができます。

  1. 繰り返しを使用して
#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;
}
  1. 再帰的に
#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 項を求めますが、通常はループを使用したほうが効率的です。しかし、再帰を使用したほうがより簡潔です。

bannerAds