首页 > 代码库 > 【51NOD-0】1058 N的阶乘的长度
【51NOD-0】1058 N的阶乘的长度
【算法】数学
【题解】n!的位数相当于ans=log10(n!)上取整,然后就可以拆出来加了。
可以用log10(i)或log(i)/log(10)
阶乘好像有个斯特林公式……
#include<cstdio> #include<cmath> using namespace std; int main() { int n; scanf("%d",&n); long double ans=0; for(int i=1;i<=n;i++)ans+=log10(i); printf("%d",((int)ans)+1); return 0; }
【51NOD-0】1058 N的阶乘的长度
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。