解题思路: 去掉每一次求解的阶乘后面的0,然后保留非0的后三位即可。不能只保留1位哦。
参考代码:
#include<bits/stdc++.h> using namespace std; int main() { int n,i,p=1; cin>>n; for(i=2;i<=n;i++) { p=p*i; while(p%10==0) //去掉阶乘后面的0 p=p/10; p=p%1000; //取最后三位 } cout<<p%10; //取最后一位作为结果输出 return 0; }
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:763 |
高精度加法 (C++代码)(大数加法)浏览:934 |
C语言程序设计教程(第三版)课后习题11.8 (C语言代码)浏览:622 |
字符串输入输出函数 (Java代码)浏览:1440 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:608 |
printf基础练习2 (C语言代码)浏览:305 |
C语言训练-尼科彻斯定理 (C语言代码)浏览:469 |
WU-蓝桥杯算法提高VIP-Quadratic Equation (C++代码)浏览:1754 |
母牛的故事 (C语言代码)浏览:1428 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:529 |