Big Number poj-1423
题目大意:给出一个自然数n,求n!的位数。
注释:n<=$10^7$。
想法:我们显然知道了,直接暴力显然会T掉,而且需要高精度的存在。所以,在此,我们介绍一种公式——Stirling公式。
Stirling公式:$n!\approx\sqrt{2\pi n}(\frac{n}{e})^n$。
令
data:image/s3,"s3://crabby-images/8de84/8de8484c8287f299d81dabfc93f3d7dd776ac75a" alt="技术分享图片"
则
data:image/s3,"s3://crabby-images/0ae4f/0ae4f1aae2ad5b0e46e39b6fbfd706d578fe8aaa" alt="技术分享图片"
data:image/s3,"s3://crabby-images/3592e/3592ec93a318a8b76682610832a1a7efa3fab5a1" alt="技术分享图片"
data:image/s3,"s3://crabby-images/8a42f/8a42fcedbcaadbebbcc27ed4344ae5f789d7803d" alt="技术分享图片"
所以
即
,即单调递减,又由积分放缩法有
data:image/s3,"s3://crabby-images/8b0af/8b0afeb5af2e5be58b3194e5b5354e83e27c7839" alt="技术分享图片"
data:image/s3,"s3://crabby-images/516c0/516c0b65113b7750e63cacb5d311938b124f66d0" alt="技术分享图片"
data:image/s3,"s3://crabby-images/1a655/1a655328a1c13b907cf570473dee6c5ed1d41264" alt="技术分享图片"
即
,即
data:image/s3,"s3://crabby-images/2e6b0/2e6b0c0d810db22f868ab7aaa1626b035ec1d9fb" alt="技术分享图片"
data:image/s3,"s3://crabby-images/26613/266139f3165d750535122b6c4fe164f4d11ffc79" alt="技术分享图片"
设
data:image/s3,"s3://crabby-images/bda55/bda558d12bc576f6a392a1492ddbb23bd30e1ce2" alt="技术分享图片"
data:image/s3,"s3://crabby-images/e8aae/e8aaeaa21cf9d274316ec4f70ce9a695514da6db" alt="技术分享图片"
利用Wallis公式,
data:image/s3,"s3://crabby-images/46c72/46c729d6303a65cc6ffb071e6e71e9f9d9bfd14f" alt="技术分享图片"
data:image/s3,"s3://crabby-images/32f19/32f1925f31f0a26b8ec20573e6c34fe19bacdee1" alt="技术分享图片"
所以
data:image/s3,"s3://crabby-images/38536/38536e344ab95720fa6143cb047f4c51ae5d7c65" alt="技术分享图片"
data:image/s3,"s3://crabby-images/55d59/55d59621b6184d50f29b0b51bd10375d6142448c" alt="技术分享图片"
即
粘自度娘
data:image/s3,"s3://crabby-images/2edfb/2edfbb574ad43f030b18f2f81700eedc1b2bff20" alt="技术分享图片"
最后,附上丑陋的代码... ...
1 #include <iostream> 2 #include <cstdio> 3 #include <cmath> 4 using namespace std; 5 const double e=2.7182818284590452354; 6 const double pi=3.141592653589793239; 7 inline double strling(int n) 8 { 9 return log10(2*pi*n)/2.0+n*(log10(n/e)); 10 } 11 int main() 12 { 13 int cases; 14 int n; 15 double m; 16 int answer; 17 scanf("%d",&cases); 18 while(cases--) 19 { 20 scanf("%d",&n); 21 m=0; 22 m=strling(n); 23 answer=(int)m; 24 answer++; 25 printf("%d\n",answer); 26 } 27 return 0; 28 }
小结:这种结论题就靠题量去强化吧... ...