結果
問題 | No.500 階乗電卓 |
ユーザー |
![]() |
提出日時 | 2017-11-21 11:44:14 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 1,636 bytes |
コンパイル時間 | 1,683 ms |
コンパイル使用メモリ | 165,468 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-25 03:05:32 |
合計ジャッジ時間 | 2,653 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 20 |
ソースコード
#include <bits/stdc++.h>using namespace std;#define MOD 1000000007#define INF 2000000000//#define int ll#define ll long long#define ld long double#define vi vector<int>#define p pair<int, int>#define fi first#define se second#define pb push_back#define mp make_pair#define INIT ios::sync_with_stdio(false);cin.tie(0);#define VAR(type, ...)type __VA_ARGS__;MACRO_VAR_Scan(__VA_ARGS__);template<typename T> void MACRO_VAR_Scan(T& t) { cin >> t; }template<typename First, typename...Rest>void MACRO_VAR_Scan(First& first, Rest&...rest) { cin >> first; MACRO_VAR_Scan(rest...); }#define VEC(type, c, n) vector<type> c(n);for(auto& i:c)cin>>i;#define MAT(type, c, m, n) vector<vector<type>> c(m, vector<type>(n));for(auto& r:c)for(auto& i:r)cin>>i;#define BR cout << "\n";#define SP cout << " ";#define ENDL cout<<endl;#define OUT(d) cout<<d;#define OUTL(d) cout<<d; BR;#define YES OUTL("YES")#define Yes OUTL("Yes")#define NO OUTL("NO")#define No OUTL("No")#define RET return 0;#define SUM(a, n) accumulate(a, a+n, 0)#define VSUM(v) accumulate(ALL(v), 0);#define REP(i, n) for(int i=0;i<(n);i++)#define RREP(i, n) for(int i=n-1;i>=0;--i)#define FOR(i, m, n) for(int i = m;i < n; i++)#define RFOR(i, a, b) for(int i=(b)-1;i>=(a);--i)#define AREP(a, n) for(auto (a):(n))#define ALL(a) (a).begin(),(a).end()#define IN(n, a, b) ((a)<=(n)&&(n)<(b))signed main(){ INIT;VAR(ll, n);if(n>49){OUTL("000000000000"); RET;}ll a = 1;FOR(i,1, n+1){a = (a * i) % 1000000000000;}if(n<15){OUTL(a);}else{printf("%012lld\n", a);}RET;}