結果

問題 No.771 しおり
ユーザー vwxyzvwxyz
提出日時 2022-04-30 07:12:37
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
TLE  
実行時間 -
コード長 620 bytes
コンパイル時間 73 ms
コンパイル使用メモリ 12,800 KB
実行使用メモリ 84,536 KB
最終ジャッジ日時 2024-06-29 13:04:10
合計ジャッジ時間 6,471 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample -- * 3
other TLE * 1 -- * 42
権限があれば一括ダウンロードができます

ソースコード

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