結果
| 問題 | No.37 遊園地のアトラクション |
| コンテスト | |
| ユーザー |
maspy
|
| 提出日時 | 2020-03-12 23:33:28 |
| 言語 | Python3 (3.14.3 + numpy 2.4.4 + scipy 1.17.1) |
| 結果 |
AC
|
| 実行時間 | 854 ms / 5,000 ms |
| コード長 | 639 bytes |
| 記録 | |
| コンパイル時間 | 554 ms |
| コンパイル使用メモリ | 20,824 KB |
| 実行使用メモリ | 35,064 KB |
| 最終ジャッジ日時 | 2026-04-26 15:33:37 |
| 合計ジャッジ時間 | 22,802 ms |
|
ジャッジサーバーID (参考情報) |
judge2_1 / judge1_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 27 |
ソースコード
#!/usr/bin/env python3.8
# %%
import sys
read = sys.stdin.buffer.read
readline = sys.stdin.buffer.readline
readlines = sys.stdin.buffer.readlines
import numpy as np
# %%
T = int(readline())
N = int(readline())
C = tuple(map(int, readline().split()))
V = tuple(map(int, readline().split()))
# %%
dp = np.zeros(T + 1, np.int64)
for c, v in zip(C, V):
newdp = dp.copy()
total_c = 0
total_v = 0
while v:
total_c += c
total_v += v
v //= 2
if total_c > T:
break
np.maximum(newdp[total_c:], dp[:-total_c] + total_v, out=newdp[total_c:])
dp = newdp
# %%
print(dp.max())
maspy