結果
| 問題 | No.37 遊園地のアトラクション | 
| コンテスト | |
| ユーザー |  maspy | 
| 提出日時 | 2020-03-12 23:33:28 | 
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 507 ms / 5,000 ms | 
| コード長 | 639 bytes | 
| コンパイル時間 | 247 ms | 
| コンパイル使用メモリ | 12,544 KB | 
| 実行使用メモリ | 44,716 KB | 
| 最終ジャッジ日時 | 2024-10-10 13:39:52 | 
| 合計ジャッジ時間 | 16,961 ms | 
| ジャッジサーバーID (参考情報) | judge5 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| 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())
            
            
            
        