結果
| 問題 |
No.209 Longest Mountain Subsequence
|
| コンテスト | |
| ユーザー |
chocorusk
|
| 提出日時 | 2020-09-18 17:14:20 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
RE
(最新)
AC
(最初)
|
| 実行時間 | - |
| コード長 | 609 bytes |
| コンパイル時間 | 111 ms |
| コンパイル使用メモリ | 12,544 KB |
| 実行使用メモリ | 44,732 KB |
| 最終ジャッジ日時 | 2024-06-22 08:02:51 |
| 合計ジャッジ時間 | 4,591 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | RE * 6 |
ソースコード
import sys
readline=sys.stdin.readline
import numpy as np
t=int(readline())
def myon(a):
INF=10**9+7
n=len(a)
dp=np.zeros(n, np.int32)
res=np.ones(n, np.int32)
for c in range(2, n+1):
nuo=(a[:, None]>(a+dp)[None, :])&np.tri(n, k=-1, dtype=np.bool)
newdp=np.where(nuo, a[:, None]-a[None, :], INF).min(axis=1)
add=(newdp<INF)
if not np.any(add):break
res+=add
dp=newdp
return res
def solve():
n=int(readline())
a=np.array(readline().split(), np.int32)
print(np.max(myon(a)+myon(a[::-1])[::-1])-1)
for _ in range(t):
solve()
chocorusk