結果

問題 No.93 ペガサス
ユーザー Mao-beta
提出日時 2024-03-06 02:18:59
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 1,062 ms / 5,000 ms
コード長 2,328 bytes
コンパイル時間 234 ms
コンパイル使用メモリ 82,112 KB
実行使用メモリ 322,104 KB
最終ジャッジ日時 2024-09-29 18:10:46
合計ジャッジ時間 7,072 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 16
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

import sys
import math
import bisect
from heapq import heapify, heappop, heappush
from collections import deque, defaultdict, Counter
from functools import lru_cache
from itertools import accumulate, combinations, permutations, product
sys.setrecursionlimit(1000000)
MOD = 10 ** 9 + 7
MOD99 = 998244353
input = lambda: sys.stdin.readline().strip()
NI = lambda: int(input())
NMI = lambda: map(int, input().split())
NLI = lambda: list(NMI())
SI = lambda: input()
SMI = lambda: input().split()
SLI = lambda: list(SMI())
EI = lambda m: [NLI() for _ in range(m)]
def main():
N = NI()
if N == 1:
print(1)
return
# 0N-122
# DP
# ii
#
# (i-4, i-2)±0-1
# (i-3, i-1)
# dp[i][j][f][g]: ij(<i) f(i-4, i-2)g(i-3, i-1)
dp = [[[[0]*2 for _ in range(2)] for _ in range(N)] for _ in range(N+1)]
dp[2][0][0][0] = 2
for i in range(2, N):
# i
for j in range(N):
for f in range(2):
for g in range(2):
dp[i][j][f][g] %= MOD
d = dp[i][j][f][g]
if d == 0:
continue
# (i-4, i-2)
if f:
dp[i+1][j][g][1] += d
# i-2(f=1)
dp[i+1][j+1][g][1] += d * (2-f)
# (i-3, i-1)
if g:
dp[i+1][j-1][0][0] += d
# (j(i-4, i-2)(i-3, i-1))
dp[i+1][j-1][g][0] += d * (j-f-g)
# (i+1j+2(ji-22)f=1)
dp[i+1][j][g][0] += d * (i+1-(j+2-f))
print(dp[N][0][0][0] % MOD)
if __name__ == "__main__":
main()
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0