結果
問題 |
No.1310 量子アニーリング
|
ユーザー |
![]() |
提出日時 | 2022-12-27 17:24:56 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 375 ms / 2,000 ms |
コード長 | 509 bytes |
コンパイル時間 | 249 ms |
コンパイル使用メモリ | 82,388 KB |
実行使用メモリ | 78,976 KB |
最終ジャッジ日時 | 2024-11-22 03:04:29 |
合計ジャッジ時間 | 4,308 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 |
ソースコード
N = int(input()) mod = 998244353 fac = [0]*(N+1) inv = [0]*(N+1) fac[0], inv[0] = 1, 1 for i in range(1, N+1): fac[i] = fac[i-1]*i fac[i] %= mod inv[i] = inv[i-1]*pow(i, mod-2, mod) inv[i] %= mod res = (2*pow(2,N,mod))%mod for i in range(1,N): if i+i<=N: res += (2*fac[N-2*i+2*i-1]*inv[N-2*i]*inv[2*i-1]*pow(2,abs(N-4*i),mod))%mod res %= mod if i+i+1<=N: res += (2*fac[N-2*i-1+2*i]*inv[N-2*i-1]*inv[2*i]*pow(2,abs(N-4*i),mod))%mod res %= mod print(res)