結果
問題 | No.554 recurrence formula |
ユーザー |
|
提出日時 | 2017-09-24 00:58:42 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 520 bytes |
コンパイル時間 | 183 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 23,296 KB |
最終ジャッジ日時 | 2024-11-14 05:47:02 |
合計ジャッジ時間 | 21,235 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 16 TLE * 5 |
ソースコード
# -*- coding: utf-8 -*- import sys N = int(input()) M = 10**9 + 7 dp = [0] * (10**5 + 1) def recurrence(n): if n==1: dp[n] = 1 elif n==2: dp[n] = 2 elif n==3: dp[n] = 6 elif n==4: dp[n] = 28 else: #dp[n] = (n * (dp[n-2]//(n-2)%M + dp[n-1]%M)) % M for i in range(n-1, 0, -2): dp[n] += dp[i] % M dp[n] *= n dp[n] %= M return dp[n] sys.setrecursionlimit(10**5+1) for i in range(1, N+1): recurrence(i) print(dp[N])