私はこの再帰的な階乗関数を持っています:
public class Driver{
public static void main (String args[])
{
System.out.println(factorial(5));
}
private static int factorial(int n)
{
int product;
if (n <= 2){ product = n; return 2;}
else{
product = n * factorial(n-1);
System.out.println("current product =" + product);
System.out.println("product = " + n + " * factorial(" + (n-1) + ")");
}
return product;
}
}
次のように出力されます。
current product =6
product = 3 * factorial(2)
current product =24
product = 4 * factorial(3)
current product =120
product = 5 * factorial(4)
120
私は一体何がここで起こっているのかを理解しようとしています。n = 2で印刷が開始される方法がわかりません。また、現在の製品= 6はどこから来たのですか?ありがとう!