結果

問題 No.2982 Logic Battle
ユーザー むつある
提出日時 2024-12-07 00:42:59
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 373 ms / 2,000 ms
コード長 1,607 bytes
コンパイル時間 469 ms
コンパイル使用メモリ 82,300 KB
実行使用メモリ 83,708 KB
最終ジャッジ日時 2024-12-07 00:43:09
合計ジャッジ時間 9,298 ms
ジャッジサーバーID
(参考情報)
judge4 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 38
権限があれば一括ダウンロードができます

ソースコード

diff #

n=int(input())

dp0=[-1]*(n+1)
dp1=[-1]*(n+1)
dp2=[-1]*(n+1)
dp0[0]=0
dp1[0]=0
dp2[0]=0

for v in range(1,n+1)[::-1]:
  ndp0=[-1]*(n+1)
  ndp1=[-1]*(n+1)
  ndp2=[-1]*(n+1)
  a=list(map(int,input().split()))
  for i in range(n):
    if dp0[i]!=-1:
      p=min(n,max(0,i+a[1]-1))
      if p!=n:
        ndp1[p]=max(ndp1[p],dp0[i]+i+a[1])
      else:
        ndp1[n]=max(ndp1[n],dp0[i]+(i+a[1]-1)*v+1)
      p=min(n,max(0,i+a[2]-1))
      if p!=n:
        ndp2[p]=max(ndp2[p],dp0[i]+i+a[2])
      else:
        ndp2[n]=max(ndp2[n],dp0[i]+(i+a[2]-1)*v+1)

    if dp1[i]!=-1:
      p=min(n,max(0,i+a[0]-1))
      if p!=n:
        ndp0[p]=max(ndp0[p],dp1[i]+i+a[0])
      else:
        ndp0[n]=max(ndp0[n],dp1[i]+(i+a[0]-1)*v+1)
      p=min(n,max(0,i+a[2]-1))
      if p!=n:
        ndp2[p]=max(ndp2[p],dp1[i]+i+a[2])
      else:
        ndp2[n]=max(ndp2[n],dp1[i]+(i+a[2]-1)*v+1)

    if dp2[i]!=-1:
      p=min(n,max(0,i+a[0]-1))
      if p!=n:
        ndp0[p]=max(ndp0[p],dp2[i]+i+a[0])
      else:
        ndp0[n]=max(ndp0[n],dp2[i]+(i+a[0]-1)*v+1)
      p=min(n,max(0,i+a[1]-1))
      if p!=n:
        ndp1[p]=max(ndp1[p],dp2[i]+i+a[1])
      else:
        ndp1[n]=max(ndp1[n],dp2[i]+(i+a[1]-1)*v+1)
    
  if dp0[n]!=-1:
    ndp1[n]=max(ndp1[n],dp0[n]+(a[1]-1)*v+1)
    ndp2[n]=max(ndp2[n],dp0[n]+(a[2]-1)*v+1)

  if dp1[n]!=-1:
    ndp0[n]=max(ndp0[n],dp1[n]+(a[0]-1)*v+1)
    ndp2[n]=max(ndp2[n],dp1[n]+(a[2]-1)*v+1)

  if dp2[n]!=-1:
    ndp1[n]=max(ndp1[n],dp2[n]+(a[1]-1)*v+1)
    ndp0[n]=max(ndp0[n],dp2[n]+(a[0]-1)*v+1)
    

  dp0=ndp0
  dp1=ndp1
  dp2=ndp2
  
print(max(max(dp0),max(dp1),max(dp2)))
0