結果
問題 | No.314 ケンケンパ |
ユーザー |
![]() |
提出日時 | 2023-10-15 15:15:36 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 61 ms / 1,000 ms |
コード長 | 403 bytes |
コンパイル時間 | 138 ms |
コンパイル使用メモリ | 82,384 KB |
実行使用メモリ | 67,172 KB |
最終ジャッジ日時 | 2024-09-16 22:00:53 |
合計ジャッジ時間 | 1,857 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 17 |
ソースコード
# やり方違った気がするが1次元dp # dp[i]Pを置く場合数、答えは最後の3項の合計 N = int(input()) mod = 10**9+7 dp = [0]*(N+1) dp[0] = 1 for i in range(N+1): dp[i] %= mod if i+2 <= N: dp[i+2] += dp[i] if i+3 <= N: dp[i+3] += dp[i] if N == 1: ans = 1 elif N == 2: ans = 2 elif N >= 3: ans = dp[N]+dp[N-1]+dp[N-2] ans %= mod print(ans)