結果
| 問題 | No.783 門松計画 |
| コンテスト | |
| ユーザー |
vwxyz
|
| 提出日時 | 2022-04-09 15:53:47 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 239 ms / 2,000 ms |
| コード長 | 697 bytes |
| 記録 | |
| コンパイル時間 | 168 ms |
| コンパイル使用メモリ | 82,372 KB |
| 実行使用メモリ | 77,640 KB |
| 最終ジャッジ日時 | 2025-01-01 19:48:18 |
| 合計ジャッジ時間 | 3,500 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 27 |
ソースコード
import sys
readline=sys.stdin.readline
N,C=map(int,readline().split())
L=list(map(int,readline().split()))
W=list(map(int,readline().split()))
inf=1<<10
dp=[-inf]*(N*N*(C+1))
for i in range(N):
for j in range(N):
for k in range(N):
if W[i]+W[j]+W[k]<=C and L[i]!=L[k] and (L[i]-L[j])*(L[k]-L[j])>0:
dp[(W[i]+W[j]+W[k])*N*N+j*N+k]=L[i]+L[j]+L[k]
for c in range(C+1):
for i in range(N):
for j in range(N):
for k in range(N):
if L[i]!=L[k] and (L[i]-L[j])*(L[k]-L[j])>0 and c+W[k]<=C:
dp[(c+W[k])*N*N+j*N+k]=max(dp[(c+W[k])*N*N+j*N+k],dp[c*N*N+i*N+j]+L[k])
ans=max(dp)
if ans<0:
ans=0
print(ans)
vwxyz