結果
問題 |
No.557 点対称
|
ユーザー |
![]() |
提出日時 | 2020-04-04 22:13:02 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 2,000 ms |
コード長 | 625 bytes |
コンパイル時間 | 2,152 ms |
コンパイル使用メモリ | 191,496 KB |
最終ジャッジ日時 | 2025-01-09 14:08:12 |
ジャッジサーバーID (参考情報) |
judge5 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 30 |
ソースコード
#include<bits/stdc++.h> #define ALL(v) std::begin(v),std::end(v) using lint=long long; using lubl=long double; lint mod=1'000'000'007; lint mul(lint x,lint y){return x*y%mod;} lint&mul_assign(lint&x,lint y){return x=x*y%mod;} lint power(lint x,lint p){ lint ans=1; for(;p;p>>=1){ if(p&1)mul_assign(ans,x); mul_assign(x,x); } return ans; } int main(){ std::cin.tie(nullptr);std::ios_base::sync_with_stdio(false); std::cout.setf(std::ios_base::fixed);std::cout.precision(15); lint n;std::cin>>n; std::cout<<(n==1?2:mul(mul(power(3,n%2),power(5,std::max(0ll,n/2-1))),4))<<'\n'; }