結果
| 問題 |
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 |
ソースコード
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)))
むつある