Trailing Zeroes (III) (数学)
来源:互联网 发布:软件语言培训学校 编辑:程序博客网 时间:2024/05/21 18:44
You task is to find minimal natural number N, so that N! contains exactly Q zeroes on the trail in decimal notation. As you know N! = 1*2*...*N. For example, 5! = 120, 120 contains one zero on the trail.
Input
Input starts with an integer T (≤ 10000), denoting the number of test cases.
Each case contains an integer Q (1 ≤ Q ≤ 108) in a line.
Output
For each case, print the case number and N. If no solution is found then print 'impossible'.
Sample Input
3
1
2
5
Sample Output
Case 1: 5
Case 2: 10
Case 3: impossible
【题意】输入一个数,表示阶乘值末尾0的个数,求满足条件的最小数。
这道题的关键在于怎么知道一个数阶乘值末尾0的个数,因为数据庞大,不可能正常计算出来,所以就要采取一定的数学方法,经过尝试可以知道,1~4的阶乘值末尾没有0,5~9的阶乘值末尾一个0,10~14的阶乘值末尾2个0,但是!!!末尾三个0的数没有,所以用而二分就可以找出这样的数,具体看代码:
#include<iostream>#include<cstdio>#include<cstring>using namespace std;typedef long long LL;LL ans(LL n){ LL ss=0; while(n) { ss+=n/5; n/=5; } return ss;}int main(){ int t; LL m,a; scanf("%d",&t); for(int i=1;i<=t;i++) { scanf("%lld",&m); LL l=1,r=1e12; a=0; while(r>=l) { LL mid=(l+r)>>1; if(ans(mid)==m) { a=mid; r=mid-1; } else if(ans(mid)>m) r=mid-1; else l=mid+1; } if(a) printf("Case %d: %lld\n",i,a); else printf("Case %d: impossible\n",i); } return 0;}
阅读全文
0 0
- Trailing Zeroes (III) (数学)
- *lightoj 1138 Trailing Zeroes (III) | 二分+数学
- Trailing Zeroes (III)<二分>
- Trailing Zeroes (III)
- Trailing Zeroes (III)
- lightoj Trailing Zeroes (III)
- Trailing Zeroes (III) LightOJ
- Trailing Zeroes (III)
- Trailing Zeroes (III)
- acm Trailing Zeroes (III)
- 二分法-Trailing Zeroes (III)
- Trailing Zeroes (III)
- Trailing Zeroes (III)
- LightOJ1138 Trailing Zeroes (III)
- Trailing Zeroes (III)
- Trailing Zeroes (III)
- Light oj-1138 Trailing Zeroes (III) (二分&数学)
- 【Light-oj】-1138 - Trailing Zeroes (III)(二分,数学)
- linux系统配置序列号
- codeforces 814D An overnight dance in discotheque(贪心)
- 46 《未来的工作》 -豆瓣评分7.0
- Linux下修改tomcat JVM内存大小
- Scala入门到精通——第二十七节 Scala操纵XML
- Trailing Zeroes (III) (数学)
- Jlink接口的Jtag和SWD接口定义
- openstack及其核心项目
- Maven学习笔记----使用Maven创建Java项目
- ArcGIS9.3 插件开发的dll如何在ArcMap等桌面端产品用起来
- android 需要常量表达式
- cocos2dx lua开发调试打log方式
- 关于qt中的tr()函数
- Java中的Callable和Future