51Nod 1058 N的階乘的長度
阿新 • • 發佈:2017-10-06
nbsp urn syn ext div pac wap set sync
輸入N求N的階乘的10進制表示的長度。例如6! = 720,長度為3。
Input
輸入N(1 <= N <= 10^6)Output
輸出N的階乘的長度Input示例
6Output示例
3
很基礎的題目,算是復習了一波log運算吧。
一個數的位數就是其對10取對數之後+1,那麽:
log10(n!) = log10(1) + ... + log10(n)。
51Nod 上面數據似乎不是很嚴,直接用這個也過了。
還有一種算法。點擊進入
//Asimple #include <bits/stdc++.h> //#define INF 0x3fffffff#define swap(a,b,t) t = a, a = b, b = t #define CLS(a, v) memset(a, v, sizeof(a)) #define debug(a) cout << #a << " = " << a <<endl #define test() cout<<"=========="<<endl using namespace std; typedef long long ll; const int maxn = 50000+5; const double PI=acos(-1.0); //const ll mod = 1000005; const int INF = ( 1 << 20 ) ; const int dx[] = {-1, 0, 1, 0}; const int dy[] = { 0,-1, 0, 1}; ll n, m, res, ans, len, T, k, num, sum; ll mod; void input() { ios_base::sync_with_stdio(false); while( cin >> n ) { double t = 0.0; for(inti=1; i<=n; i++) t += log10(i); ans = (ll)( t + 1 ); cout << ans << endl; } } int main(){ input(); return 0; }
51Nod 1058 N的階乘的長度