Luogu CF633B 【A Trivial Problem】题解
一段理解起来特别容易的代码 (目前来看是最短的)
思路
由于末尾0的个数就是阶乘中分解出10的个数,也就是分解出2的个数与5的个数中的最小值;
显然5的个数小于2的个数,即找出分解出的5的个数。
比较容易推出:当
由此还可以得出另一个重要结论:若找得到,则输出的数的个数必定为
这两个结论都对解题有很大帮助。(不很理解的可以看样例分析)
样例分析
末尾
当找到
因此输入
当找到
数据较小,可以暴力循环。
用一个变量存储当前分解出5的个数,直接往下找就行。
其他的各种细节都在注释里了。
//By Vanilla_RX
#include<bits/stdc++.h>//万能头.
using namespace std;
int main(){
int m,t=0;//t存储的是当前能被分解出来的5的个数.
bool ok=0;//判断是否找到t使得t=m.
scanf("%d",&m);//输入.
for(int i=1;i<=5000001;i++){
int j=i;
while(j%5==0){
t++;
j/=5;
}//分解出5.
if(!ok&&t==m) cout<<"5\n";//找到了且未输出i就输出5.
if(t==m){
ok=1;
cout<<i<<" ";
}//输出符合要求的i.
if(ok&&t!=m) return 0;//如果找完了就结束.
}
cout<<0;//未找到就输出0.
return 0;//结束.
}
祝早日AC!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现