結果
問題 |
No.1238 選抜クラス
|
ユーザー |
|
提出日時 | 2025-05-10 15:37:41 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 395 ms / 2,000 ms |
コード長 | 927 bytes |
コンパイル時間 | 428 ms |
コンパイル使用メモリ | 82,420 KB |
実行使用メモリ | 104,192 KB |
最終ジャッジ日時 | 2025-05-10 15:37:50 |
合計ジャッジ時間 | 8,193 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 36 |
ソースコード
## https://yukicoder.me/problems/no/1886 MOD = 10 ** 9 + 7 def main(): N, K = map(int, input().split()) A = list(map(int, input().split())) dp = [[0] for _ in range(1)] dp[0][0] = 1 max_a = max(A) for n in range(N): a = A[n] new_dp = [[0] * (max_a * m + 1) for m in range(n + 2)] for m in range(n + 1): for k in range(max_a * m + 1): x = dp[m][k] new_dp[m][k] += x new_dp[m][k] %= MOD new_k = min(k + a, max_a * (m + 1)) new_dp[m + 1][new_k] += x new_dp[m + 1][new_k] %= MOD dp = new_dp answer = 0 for n in range(1, N + 1): for k in range(max_a * n + 1): if k >= K * n: answer += dp[n][k] answer %= MOD print(answer) if __name__ == "__main__": main()