結果
| 問題 |
No.2156 ぞい文字列
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-12-09 21:38:36 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 43 ms / 2,000 ms |
| コード長 | 782 bytes |
| コンパイル時間 | 793 ms |
| コンパイル使用メモリ | 82,432 KB |
| 実行使用メモリ | 52,736 KB |
| 最終ジャッジ日時 | 2024-10-14 21:04:08 |
| 合計ジャッジ時間 | 2,139 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 16 |
ソースコード
import sys
input = lambda: sys.stdin.readline().rstrip()
MOD = 998244353
def even(P):
return P[0::2]
def odd(P):
return P[1::2]
def mul(P, Q):
N = len(P); M = len(Q)
R = [0]*(N+M-1)
for i in range(N):
for j in range(M):
R[i+j] += P[i]*Q[j]
R[i+j] %= MOD
return R
def negx(Q):
return [(-n if i&1 else n) for i, n in enumerate(Q)]
def bostan_mori(N, P, Q):
while N > 0:
Qx = negx(Q)
U = mul(P, Qx)
if N&1: P = odd(U)
else: P = even(U)
Q = even(mul(Q, Qx))
N >>= 1
return P[0] * pow(Q[0], MOD-2, MOD)
def main():
# 入力
N = int(input())
# 計算・出力
print(bostan_mori(N+1, [0, 1], [1, -1, -1]) - 1)
if __name__ == "__main__":
main()