版权声明:菜鸟一枚~~ 有想法可在下面评论, 转载标明出处即可。 https://blog.csdn.net/KLFTESPACE/article/details/82526450
问题描述
给定n和len,输出n!末尾len位。
输入格式
一行两个正整数n和len。
输出格式
一行一个字符串,表示答案。长度不足用前置零补全。
样例输入
6 5
样例输出
00720
数据规模和约定
n<=30, len<=10。
#include<iostream>
#include<cstdio>
using namespace std;
const int Data = 10;
int a[4000];
int main()
{
int n, len, r=0;//r代表是否进位
scanf("%d%d", &n, &len);
a[0]=1;
int j = 0;
while(n--){
for(int i=0; i<=j; i++){
a[i] = a[i]*(n+1)+r;
r = a[i]/Data;
a[i] %= Data;
}
if(r){
j++; a[j] = r; r = 0;
}
}
for(int i=len-1; i>=0; i--)
printf("%d", a[i]);;
printf("\n");
return 0;
}