結果
| 問題 |
No.107 モンスター
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-10-04 17:13:52 |
| 言語 | Python2 (2.7.18) |
| 結果 |
AC
|
| 実行時間 | 3,969 ms / 5,000 ms |
| コード長 | 490 bytes |
| コンパイル時間 | 63 ms |
| コンパイル使用メモリ | 7,040 KB |
| 実行使用メモリ | 110,156 KB |
| 最終ジャッジ日時 | 2024-12-21 07:22:24 |
| 合計ジャッジ時間 | 15,718 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 21 |
ソースコード
N = input()
D = map(int, raw_input().split())
done = 2**N-1
mem = {}
def rec(b, hp, maxhp):
if (b, hp) in mem:
return mem[(b, hp)]
if b == done:
return hp
m = 0
for i in xrange(N):
if (1<<i) & b:
continue
if D[i] > 0:
m = max(m, rec(b+(1<<i), min(hp+D[i], maxhp), maxhp))
elif hp + D[i] > 0:
m = max(m, rec(b+(1<<i), hp+D[i], maxhp+100))
mem[(b, hp)] = m
return m
print rec(0, 100, 100)