結果

問題 No.771 しおり
ユーザー vwxyz
提出日時 2022-04-30 07:12:47
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 948 ms / 2,000 ms
コード長 620 bytes
コンパイル時間 183 ms
コンパイル使用メモリ 82,792 KB
実行使用メモリ 134,088 KB
最終ジャッジ日時 2024-07-22 07:31:25
合計ジャッジ時間 13,983 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 43
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys
readline=sys.stdin.readline

N=int(readline())
A,B=[],[]
for _ in range(N):
    a,b=map(int,readline().split())
    b-=a
    A.append(a)
    B.append(b)
inf=1<<30
dp=[[inf]*N for bit in range(1<<N)]
for i in range(N):
    dp[1<<i][i]=0
for bit in range(1<<N):
    lst=[i for i in range(N) if bit&1<<i]
    l=len(lst)
    for j in range(l):
        for i in range(j):
            x,y=lst[i],lst[j]
            if bit&1<<x and bit&1<<y:
                dp[bit][x]=min(dp[bit][x],max(dp[bit^1<<x][y],B[y]+A[x]))
                dp[bit][y]=min(dp[bit][y],max(dp[bit^1<<y][x],B[x]+A[y]))
ans=min(dp[-1])
print(ans)
0