多个方法计算n的阶乘(Java)

Java实现for循环、while循环、do-while循环、递归计算得到n的阶乘。

代码

package section_2;
import java.util.Scanner;						//!!!引入包


public class A2_19 {
	
	static int  factorial(int n){				//递归函数
		int l=n-1;
       		 if(n==1){
            			return 1;
        		}
        		else{
        			System.out.print("*"+l);
        			l--;
            			return n*factorial(n-1);
        		}
    	}

	
	public static void main(String[] args){
		Scanner input=new Scanner(System.in); 	//!!!输入	
		System.out.println("请输入数字n:");
		int n=input.nextInt();					//!!!键盘输入
		int n1 = n,n2=n,n3=n,n4=n;
		int i,j =n-1,k=n-1;
		
		
		//001	for
		System.out.printf("for循环计算得n!="+n);
		for(i=n-1;i>0;i--){
			n1=n1*i;
			System.out.printf("*"+i);
		}
		System.out.println("="+n1);
		
		//002	while
		System.out.printf("while循环计算得n!="+n);
		while(j>0){
			n2=n2*j;
			System.out.printf("*"+j);
			j--;
		};
		System.out.println("="+n2);
		
		//003	do-while
		System.out.printf("do-while循环计算得n!="+n);
		do{
			n3=n3*k;
			System.out.printf("*"+k);
			k--;
		}while(k>0);
		System.out.println("="+n3);
		
		//004	递归
		System.out.printf("递归计算得n!="+n);
		n4=factorial(n);
		System.out.println("="+n4);
		
		
	}

}

 

你可能感兴趣的:(Java)