結果

問題 No.286 Modulo Discount Store
ユーザー nebukuro09
提出日時 2016-10-12 16:00:14
言語 PyPy2
(7.3.15)
結果
AC  
実行時間 609 ms / 2,000 ms
コード長 472 bytes
コンパイル時間 1,863 ms
コンパイル使用メモリ 76,416 KB
実行使用メモリ 134,856 KB
最終ジャッジ日時 2024-11-22 02:43:11
合計ジャッジ時間 9,005 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 40
権限があれば一括ダウンロードができます

ソースコード

diff #

N = input()
M = [int(raw_input()) for _ in xrange(N)]

mem = {}
def rec(p, b, acm):
    if b == ((1 << N) - 1):
        return 0
    if (p, b) in mem:
        return mem[(p, b)]
    m = float('inf')
    for i in xrange(N):
        if (1 << i) & b:
            continue
        price = max(0, M[i]-(acm%1000))
        m = min(m, rec(i, b+(1<<i), acm+M[i])+price)
    mem[(p, b)] = m
    return mem[(p, b)]
            
print min(rec(i, 1<<i, M[i])+M[i] for i in xrange(N))
0