結果
問題 | No.500 階乗電卓 |
ユーザー |
![]() |
提出日時 | 2019-05-18 01:57:45 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 2,173 bytes |
コンパイル時間 | 836 ms |
コンパイル使用メモリ | 96,656 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-17 06:04:42 |
合計ジャッジ時間 | 1,590 ms |
ジャッジサーバーID (参考情報) |
judge6 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 20 |
ソースコード
#include <iostream>#include <cmath>#include <vector>#include <string>#include <map>#include <algorithm>#include <numeric>#include <fstream>#include <iomanip>typedef long double ld;typedef long long ll;const ll INF = (ll)1e18 + 1;const ll MOD = 1e12;// Splitnamespace util {std::vector< std::string > split(std::string s, char delimiter){std::vector< std::string > vs;std::string sub;for (auto c : s) {if (c == delimiter) vs.push_back(sub), sub.clear();else sub += c;}vs.push_back(sub);return vs;}} // namespace util// Minimum, Maximumtemplate<class T> T minimum(T head, T tail) { return std::min(head, tail); }template<class H, class... T> H minimum(H head, T... tail) { return std::min(head, minimum(tail...)); }template<class T> T maximum(T head, T tail) { return std::max(head, tail); }template<class H, class... T> H maximum(H head, T... tail) { return std::max(head, maximum(tail...)); }// Outputtemplate<class T, class S> std::ostream& operator << (std::ostream& os, std::pair<T, S> p){return os << p.first << " " << p.second;}template<class T> std::ostream& operator << (std::ostream& os, std::vector< T > v){for (ll i = 0; i < (ll)v.size(); i++){ os << " [" << i << "]" << v[i]; if (i % 10 == 9) os << std::endl; }return os;}template<class T, class S> std::ostream& operator << (std::ostream& os, std::vector< std::pair<T, S> > vp){ll i = 0;for (auto p : vp){os << " [" << i++ << "]" << p.first << " " << p.second; if (i % 10 == 0) os << std::endl;}return os;}void print(){ std::cout << std::endl; }template<typename H> void print(H head) { std::cout << head << std::endl; }template<typename H, typename... T> void print(H head, T... tail){ std::cout << head << " ", print(tail...); }int main(){std::cin.tie(nullptr);std::ios::sync_with_stdio(false);ll N;std::cin >> N;ll ans = 1;if (N < 50) {for (ll i = 1; i <= N; i++) {ans = (ans * i) % MOD;}if (N >= 15) {std::cout << std::setfill('0') << std::setw(12) << ans << std::endl;} else {print(ans);}} else {print("000000000000");}return 0;}