結果
| 問題 |
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()