結果
問題 |
No.1043 直列大学
|
ユーザー |
![]() |
提出日時 | 2020-05-01 22:11:33 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 644 bytes |
コンパイル時間 | 195 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 35,840 KB |
最終ジャッジ日時 | 2024-12-25 11:39:16 |
合計ジャッジ時間 | 65,229 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 7 TLE * 21 |
ソースコード
n, m = map(int, input().split()) vs = list(map(int, input().split())) rs = list(map(int, input().split())) a, b = map(int, input().split()) v_sum = [0 for _ in range(100001)] v_sum[0] = 1 r_sum = [0 for _ in range(100001)] r_sum[0] = 1 for v in vs: for i in range(100000, v-1, -1): v_sum[i] += v_sum[i-v] for r in rs: for i in range(100000, r-1, -1): r_sum[i] += r_sum[i-r] v_cum = [1 for _ in range(100001)] for i in range(1, 100001): v_cum[i] = v_cum[i-1] + v_sum[i] MOD = 10**9+7 ans = 0 for i in range(1, 100001): x, y = min(a*i-1, 100000), min(b*i, 100000) num = v_cum[y] - v_cum[x] ans += num * r_sum[i] ans %= MOD print(ans)