ユーザーが入力した数 n に対してオイラー数 e を求めたいのですが、論理部分に問題があり、2 を入力すると 2.5 の正解が得られないようで、代わりに 2 が得られます。入力が何であれ、常に2の答えを得ます。階乗は正しい答えを出力するため、問題はオイラー法にあります。これがコードです。
import java.util.*;
public class pract5ex3 {
public static int fact (int n){
if (n==0 || n==1){
return 1;
}
else {
return n*fact(n-1);
}
}
public static double constantRec(int n){
if (n == 0){
return 1;
}
else {
return 1/fact(n)+constantRec(n-1);
}
}
public static void main (String []args) {
Scanner s= new Scanner (System.in);
System.out.println("enter number");
int n =s.nextInt();
int factorial = pract5ex3.fact(n);
double euler = pract5ex3.constantRec(n);
System.out.println(factorial);
System.out.println(euler);
}
}