N的阶乘(大整数)

题目描述

 输入一个正整数N,输出N的阶乘。

输入描述:

正整数N(0<=N<=1000)

输出描述:

 输入可能包括多组数据,对于每一组输入数据,输出N的阶乘

示例1

输入

复制

4
5
15

输出

复制

24
120
1307674368000
//C++实现

#include <cstdio>
#include <cstring>
using namespace std;
struct bign{
	int d[100000];
	int len;
	bign(){
		memset(d,0,sizeof(d));
		len=0;
	}
};
bign change(char str[]){
	bign a;
	a.len=strlen(str);
	for(int i=0;i<a.len;i++){
		a.d[i]=str[a.len-i-1]-'0';
	}
	return a;
}
bign muti(bign a,int b){
	bign c;
	int carry=0;
	for(int i=0;i<a.len;i++){
		int temp=a.d[i]*b+carry;
		c.d[c.len++]=temp%10;
		carry=temp/10;
	}
	while(carry!=0){
		c.d[c.len++]=carry%10;
		carry/=10;
	}
	return c;
}

bign fun(int n){
	bign sum;
	sum.d[0]=1;
	sum.len=1;
	while(n!=1){
		sum=muti(sum,n);
		n--;
	}
	return sum;
}
void print(bign a){
	for(int i=a.len-1;i>=0;i--){
		printf("%d",a.d[i]);
	}
	printf("\n");
}
int main(){
    int n;
    while(scanf("%d",&n)!=EOF){
        bign sum;
		sum=fun(n);
		print(sum);
    }
    return 0;
}
//java实现

import java.math.BigInteger;
import java.util.Scanner;
public class Main{
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        while(sc.hasNext()){
            int number=sc.nextInt();
            System.out.println(fun(number));
        }
    }
    public static BigInteger fun(int number){
        if(number==1){
            return BigInteger.valueOf(1);
        }else
            return fun(number-1).multiply(BigInteger.valueOf(number));
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章