Java实现阶乘运算(递归、循环)

Java实现阶乘运算(递归、循环)

开发工具与关键技术:Myeclipse 10,java语言
作者:清晨
撰写时间:2019.4.17

下面我们使用递归与循环

以及输出的截图:
Java实现阶乘运算(递归、循环)_第1张图片

/**
 * 递归阶级算法,for循环
 */
public class Recursion {
	public static void main(String[] args) {
	
		System.out.println("欢迎来到树先生的世界!");
		System.out.println("输入要计算的值:");
		
		//system.in是输入
		Scanner sc = new Scanner(System.in);
		
		//读取输入的那一行的值
		String inta = sc.nextLine();
		
		//判断matches
		if (!inta.matches("\\d+")) {
			System.out.println("请确认您输入的是正数的数字?程序终止了");
			
			return;
		}
		//将String类型转换Integer
		Integer integer = new Integer(inta);
		
		//用的类型是long类型可以计算到40的阶乘
		if (integer>40) {
		
			System.out.println("数字过大。请输入1~40之间的值");
			
			//过大会停止程序
			return;
		}
		
		//传进去的参数
		System.out.println("递归的结果是:" + factorial(integer));
		System.out.println("循环的结果是:" + doFactorial(integer));
	}

	// 递归方法
	public static long factorial(int num) {
		//当参数等于1时返回本身
		if (num == 1) {
			return 1;
		} 
		
		   //用long是为了计算跟多的值long的范围比较大
			long digui= (long) (factorial(num - 1)*num);// 阶乘的算法factorial(num-1)*num
			System.out.print("当" + num + "时 ,结果是:"+ digui);
			System.out.println();
			
		return digui;
	}
   //(循环方法)
  //long 是返回类型
	public static long doFactorial(int num) {
		long result = 1;
		
		for (int i = 0; i < num; i++) {
		
			// result *= i;累积
			result = result * (i + 1);
		}
		
		//返回值
		return result;

	}
}

你可能感兴趣的:(Technology)