解题思路: 去掉每一次求解的阶乘后面的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语言代码)浏览:1525 |
【偶数求和】 (C++代码)浏览:702 |
C语言程序设计教程(第三版)课后习题9.4 (Java代码)浏览:1416 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:749 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1282 |
printf基础练习2 (C语言代码)浏览:741 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:672 |
a+b浏览:432 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:556 |
杨辉三角 (C语言代码)浏览:484 |