n的阶乘的长度

斯特林公式:

N!=(N/e)^n*sqrt(2*pi*n)

位数:ans.

两边同时对10取对数,ans=log10N!=n*log10(N/e)+log10(2*pi*n)+1;

代码实现:

#include<bits/stdc++.h>
using namespace std;
int main(){
	int n,ans=1;
	while(cin>>n)
	{  if(n>3)
	   ans=log10(2*M_PI*n)/2+n*log10(n/M_E)+1;
	   cout<<ans<<endl;  (n小于等于3的话,ans还是1,直接输出就行了)
	}
	return 0;
}

 

 

 

全部评论

相关推荐

11-04 10:30
已编辑
门头沟学院 研发工程师
开心小狗🐶:“直接说答案”
点赞 评论 收藏
分享
10-28 17:30
已编辑
华东交通大学 Java
想进开水团喝开水:字节的hr的本职工作就是黄金矿工
秋招笔试记录
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务