結果
問題 |
No.1045 直方体大学
|
ユーザー |
![]() |
提出日時 | 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 |
ソースコード
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)