Merge pull request #1251 from wendelllsc/patch-1

Using Try/catch and recursion
This commit is contained in:
Stepfen Shawn
2020-05-11 22:53:24 +08:00
committed by GitHub

View File

@ -19,13 +19,16 @@ public class Factorial {
* @return the factorial of {@code n}
*/
public static long factorial(int n) {
if (n < 0) {
throw new ArithmeticException("n < 0"); //Dont work with less than 0
// Using recursion
try {
if (n == 0) {
return 1; // if n = 0, return factorial of n;
}else {
return n*factorial(n-1); // While N is greater than 0, call the function again, passing n-1 (Principle of factoring);
}
long fac = 1;
for (int i = 1; i <= n; ++i) {
fac *= i;
}catch (ArithmeticException e) {
System.out.println("Dont work with less than 0");
}
return fac; //Return factorial
return n;
}
}