結果
問題 | No.1043 直列大学 |
ユーザー |
![]() |
提出日時 | 2020-05-01 23:41:35 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 420 ms / 2,000 ms |
コード長 | 1,209 bytes |
コンパイル時間 | 318 ms |
コンパイル使用メモリ | 82,044 KB |
実行使用メモリ | 224,896 KB |
最終ジャッジ日時 | 2024-12-22 19:56:09 |
合計ジャッジ時間 | 8,544 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 28 |
ソースコード
n, m = map(int, input().split())v = list(map(int, input().split()))r = list(map(int, input().split()))a, b = map(int, input().split())MAX = 100010mod = 10**9 + 7dpv = [[0 for j in range(MAX)] for i in range(n+1)]dpr = [[0 for j in range(MAX)] for i in range(m+1)]dpv[0][0] = 1for i in range(n):for j in range(MAX):if dpv[i][j] > 0:dpv[i+1][j] += dpv[i][j]dpv[i+1][j] %= modif j + v[i] < MAX:dpv[i+1][j+v[i]] += dpv[i][j]dpv[i+1][j+v[i]] %= moddpr[0][0] = 1for i in range(m):for j in range(MAX):if dpr[i][j] > 0:dpr[i+1][j] += dpr[i][j]dpr[i+1][j] %= modif j + r[i] < MAX:dpr[i+1][j+r[i]] += dpr[i][j]dpr[i+1][j+r[i]] %= modvsum = [0 for _ in range(MAX)]for i in range(MAX-1):vsum[i+1] = vsum[i] + dpv[n][i]vsum[i+1] %= mod#和の管理 セグメント木を使わずに、変更する必要ないからans = 0for i in range(1, MAX):L, R = a*i, min(MAX-1, b*i+1)if L >= MAX:breakans += (vsum[R] - vsum[L]) % mod * dpr[m][i] % modans %= modprint(ans)