Java での再帰的フィボナッチ数列
Rashmi Patidar
2023年10月12日
フィボナッチ数列
0 と 1 から始まる最後の 2つの数値の加算によって形成されるシーケンス。n 番目の要素を検索する場合は、(n-1)と(n-2)の項を加算して数値を検索します。ここで、n は 0 より大きくなければなりません。
再帰
再帰とは、同じ決定的な関数またはプロシージャが、終了条件に遭遇するまで、それ自体を複数回呼び出すプロセスです。終了条件を指定しない場合、メソッドは無限ループ状態になります。
Java での再帰的フィボナッチ数列
以下のコードでは、main()
メソッドがクラスで定義された静的関数 getFibonacciNumberAt()
を呼び出します。この関数は、フィボナッチ数を評価する数を定義するパラメーターを取ります。この関数には、目的の条件を満たすと 0 または 1 を返すプライマリチェックがあります。それ以外の場合、関数は渡されたパラメーターをデクリメントすることにより、再び自身を呼び出します。
Java
javaCopypackage recursiveFibonacci;
public class RecursiveFibonacciSequence {
public static void main(String[] args) {
int fibonacciNumber = getFibonacciNumberAt(6);
System.out.println(fibonacciNumber);
}
public static int getFibonacciNumberAt(int n) {
if (n == 0)
return 0;
else if (n == 1)
return 1;
else
return getFibonacciNumberAt(n - 1) + getFibonacciNumberAt(n - 2);
}
}
出力:
textCopy8
詳細な評価は以下に見ることができます:
outputCopygetFibonacciNumberAt(6) = getFibonacciNumberAt(5) + getFibonacciNumberAt(4); //5+3=8
getFibonacciNumberAt(5) = getFibonacciNumberAt(4) + getFibonacciNumberAt(3); //3+2=5
getFibonacciNumberAt(4) = getFibonacciNumberAt(3) + getFibonacciNumberAt(2); //2+1=3
getFibonacciNumberAt(3) = getFibonacciNumberAt(2) + getFibonacciNumberAt(1); //1+1=2
getFibonacciNumberAt(2) = getFibonacciNumberAt(1) + getFibonacciNumberAt(0); //1+0=1
If, getFibonacciNumberAt(1) = 1;
And getFibonacciNumberAt(0) = 0;
上記のプログラムを変更して、希望する数までのシリーズを出力できます。
Java
javaCopypackage recursiveFibonacci;
public class RecursiveFibonacci {
public static void main(String[] args) {
int maxCount = 10;
for (int i = 0; i <= maxCount; i++) {
int fibonacciNumber = printFibonacci(i);
System.out.print(" " + fibonacciNumber);
}
}
public static int printFibonacci(int n) {
if (n == 0)
return 0;
else if (n == 1)
return 1;
else
return printFibonacci(n - 1) + printFibonacci(n - 2);
}
}
出力:
textCopy0 1 1 2 3 5 8 13 21 34 55
注意
より大きな数値を計算するには、Java の
BigInteger
クラスを使用できます。再帰プロセスは、数値が大きいほど複雑になります。したがって、そのような数値の計算時間も長くなります。著者: Rashmi Patidar
Rashmi is a professional Software Developer with hands on over varied tech stack. She has been working on Java, Springboot, Microservices, Typescript, MySQL, Graphql and more. She loves to spread knowledge via her writings. She is keen taking up new things and adopt in her career.
LinkedIn