大数阶乘的位数

复制代码
 1 import java.util.*;
 2 import java.math.*;
 3 class Main
 4 {
 5     public static void main(String args[])
 6     {
 7         Scanner cin=new Scanner(System.in);
 8         int i,n,m,des=0;
 9         double sum,e=2.7182818284590452354,PI=3.141592653589793239;
10         while(cin.hasNext())
11         {
12             n=cin.nextInt();
13             while(n-->0)
14             {
15                 m=cin.nextInt();
16                 if(m<100000)
17                 {
18                     for(sum=0,i=1;i<=m;i++)
19                     {
20                         sum+=Math.log10(i);
21                     }
22                 }
23                 else
24                 {
25                     sum=Math.log10(Math.sqrt(2*PI*m))+m*Math.log10(m/e);
26                 }
27                 des=(int)sum;
28                 if(des<=sum)des++;
29                 System.out.println(des);
30             }
31         }
32     }
33 }
复制代码

 

posted @   疼痛落在指尖  阅读(187)  评论(0)    收藏  举报
编辑推荐:
· 记一次 .NET某云HIS系统 CPU爆高分析
· 如果单表数据量大,只能考虑分库分表吗?
· 一文彻底搞懂 MCP:AI 大模型的标准化工具箱
· 电商平台中订单未支付过期如何实现自动关单?
· 用 .NET NativeAOT 构建完全 distroless 的静态链接应用
阅读排行:
· 如果单表数据量大,只能考虑分库分表吗?
· 一款让 Everything 更加如虎添翼的 .NET 开源辅助工具!
· (原创)[开源][.Net Framework 4.5] SimpleMVVM(极简MVVM框架)更
· 冲压车间软件实施
· 干货分享!MCP 实现原理,小白也能看懂
点击右上角即可分享
微信分享提示