結果

問題 No.1045 直方体大学
ユーザー ntuda
提出日時 2025-09-07 22:56:13
言語 PyPy3
(7.3.15)
結果
TLE  
実行時間 -
コード長 933 bytes
コンパイル時間 510 ms
コンパイル使用メモリ 82,552 KB
実行使用メモリ 100,284 KB
最終ジャッジ日時 2025-09-07 22:56:18
合計ジャッジ時間 5,143 ms
ジャッジサーバーID
(参考情報)
judge / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 6 TLE * 1 -- * 10
権限があれば一括ダウンロードができます

ソースコード

diff #

from collections import defaultdict
N = int(input())
ABC = [defaultdict(int) for _ in range(N + 1)]
ans = 0
tmp = set()
for i in range(N):
    abc = sorted(list(map(int,input().split())))
    a,b,c = abc
    ABC[1][(a,b,a,b,1<<i)] = max(ABC[1][(a,b,a,b,1<<i)], c)
    ABC[1][(a,c,a,c,1<<i)] = max(ABC[1][(a,c,a,c,1<<i)], b)
    ABC[1][(b,c,b,c,1<<i)] = max(ABC[1][(b,c,b,c,1<<i)], a)
    ans = max(ans,max(abc))

def comb(x,y):
    global ans
    xy = x + y
    N0 = len(ABC[x])
    N1 = len(ABC[y])
    for (a0,b0,c0,d0,bit0),v0 in ABC[x].items():
        for (a1,b1,c1,d1,bit1),v1 in ABC[y].items():
            if bit0 & bit1:
                continue
            if c0 >= a1 and d0 >= b1:
                ABC[xy][(a0,b0,c1,d1,bit0|bit1)] = max(ABC[xy][(a0,b0,c1,d1,bit0|bit1)],v0+v1)
                ans = max(ans,v0 + v1)

for i in range(2,N + 1):
    a = 1 << ((i-1).bit_length() - 1)
    b = i - a
    comb(a,b)
print(ans)



0