結果

問題 No.209 Longest Mountain Subsequence
ユーザー yuppe19 😺yuppe19 😺
提出日時 2016-07-06 15:21:26
言語 Nim
(2.0.2)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 680 bytes
コンパイル時間 1,267 ms
コンパイル使用メモリ 65,584 KB
最終ジャッジ日時 2024-11-14 19:46:34
合計ジャッジ時間 1,651 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
/home/judge/data/code/Main.nim(13, 19) Error: type mismatch
Expression: <n
  [1] n: int

Expected one of (first mismatch at [position]):
[1] proc `<`(x, y: bool): bool
[1] proc `<`(x, y: char): bool
[1] proc `<`(x, y: float): bool
[1] proc `<`(x, y: float32): bool
[1] proc `<`(x, y: int16): bool
[1] proc `<`(x, y: int32): bool
[1] proc `<`(x, y: int8): bool
[1] proc `<`(x, y: pointer): bool
[1] proc `<`(x, y: string): bool
[1] proc `<`(x, y: uint): bool
[1] proc `<`(x, y: uint16): bool
[1] proc `<`(x, y: uint32): bool
[1] proc `<`(x, y: uint64): bool
[1] proc `<`(x, y: uint8): bool
[1] proc `<`[Enum: enum](x, y: Enum): bool
[1] proc `<`[T: tuple](x, y: T): bool
[1] proc `<`[T](x, y: ptr T): bool
[1] proc `<`[T](x, y: ref T): bool
[1] proc `<`[T](x, y: set[T]): bool
[2] proc `<`(x, y: int): bool
[2] proc `<`(x, y: int64): bool

ソースコード

diff #

import strutils, sequtils

var
  n: int
  a: seq[int]
  dp: seq[seq[int]]
  t = stdin.readLine.parseInt

proc nya(i, j: int) : int =
  if dp[i][j] != -1: return dp[i][j]
  result = 2
  var x = a[j] - a[i]
  for k in j+1 .. <n:
    var y = a[k] - a[j]
    if (x > 0 and y > 0 and x < y) or
       (x < 0 and y < 0 and x < y) or
       (x > 0 and y < 0):
      result = max(result, nya(j, k)+1)
  dp[i][j] = result

for cases in 0 .. <t:
  n = stdin.readLine.parseInt
  a = stdin.readLine.split.map(parseInt)
  dp = newSeqWith(n, newSeqWith(n, -1))
  var res = 1
  for i in 0 .. <n:
    for j in i+1 .. <n:
      if a[i] == a[j]: continue
      res = max(res, nya(i, j))
  echo res
0