题目背景

N的阶乘写作N!,表示小于等于N的所有正整数的乘积。

题目描述

阶乘会变大得很快,如13!就必须用32位整数类型来存储,到了70!即使用浮点数也存不下了。 你的任务是找到阶乘最前面的非零位。举个例子:

5!=1*2*3*4*5=120,所以5!的最靠前的非零位是1。

7!=1*2*3*4*5*6*7=5040,所以最靠前的非零位是5。

输入输出格式

输入格式:

共一行,一个不大于4,220的正整数N

输出格式:

共一行,输出N!最靠后的非零位。

输入输出样例

输入样例#1:

7
输出样例#1:

5

说明

题目翻译来自NOCOW。

USACO Training Section 3.2

代码

 #include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#define M 262144
using namespace std; int N; int main(){
// freopen("01.in","r",stdin);
scanf("%d",&N); long long ans=;
for(long long i=;i<=N;i++){
ans*=i;
while(ans%==) ans/=;
ans%=;
}
cout<<(ans%)<<endl;
fclose(stdin);fclose(stdout);return ;
}

题目有误,样例也错,以上代码可AC,即输出最后的一位,样例 7 → 5

不过这个题目不改的话可以这样,没有数据不知道可不可以

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#define M 262144
using namespace std; int N; int main(){
freopen("01.in","r",stdin);
while(scanf("%d",&N)==1){
long long ans=1;
for(long long i=1;i<=N;i++){
ans*=i;
while(ans>=1000000000) ans/=10;
// cout<<ans<<endl;
}
while(ans>10) ans/=10;
cout<<ans<<endl;
} fclose(stdin);fclose(stdout);return 0;
}

到后面精度可能有差距,待定

最新文章

  1. php中序列化与反序列化
  2. Linux下安装SVN服务端小白教程
  3. Linux内存模型
  4. beego 0.9.0 中智能路由AutoRouter的使用方法及源码解读
  5. java.lang.String类compareTo()返回值解析
  6. 用 CALayer 定制下载进度条控件
  7. 关于使用STL常见的两个bug
  8. [置顶] 深入浅出Spring(三) AOP详解
  9. 手机浏览器下IScroll中click事件
  10. Android - 自定义控件之圆形控件
  11. 设计模式总结篇系列:模板方法模式(Template Method)
  12. 2019-2-14sql server数据库模糊查询语句
  13. Linux 问题
  14. JS数字指定长度不足前补零的实现
  15. pc-H5 适配方案
  16. linux上安装maven
  17. sql%bulk_rowcount &amp;&amp; sql%rowcount 的使用
  18. Java_如何等待子线程执行结束
  19. 20155233 2006-2007-2 《Java程序设计》第2周学习总结
  20. MQTT协议实现Eclipse Paho学习总结

热门文章

  1. ngSanitize和$sce
  2. Sublime text 3如何编辑less并转(编译)成css文件
  3. leetcode一些常用函数
  4. Ubuntu16.04安装Screenlets
  5. Intent
  6. DBCP连接池配置示例
  7. OC编程之道-接口适配之适配器
  8. 【python】tarfile的路径问题
  9. 获取URL参数值
  10. iOSIPV6简单测试环境搭建