本文为博主原创文章,未经博主允许不得转载。
题目描述
输入一个正整数n。输出n!的最高位上的数字。
输入
输入一个正整数n(n不超过1000)。
输出
输出n!的最高位上的数字。
样例输入 Copy
1000
样例输出 Copy
4
提示
注意double类型溢出问题。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
int i=1;
long s=1;
for(i=1;i<=n;i++)
{
s*=i;
while(s>=100000000)
{
s=s/10;
}
}
while(s>=10)
s=s/10;
System.out.println(s);
sc.close();
}
}
#include<stdio.h>
int main()
{
int n,i,j;
long long s;
scanf("%d",&n);
s=1;
for(i=1;i<=n;i++)
{
s*=i;
while(s>=100000000)
s=s/10;
}
while(s>=10)
s=s/10;
printf("%lld\n",s);
return 0;
}