結果

問題 No.629 グラフの中に眠る門松列
コンテスト
ユーザー siman
提出日時 2021-10-04 14:50:15
言語 Ruby
(4.0.2)
コンパイル:
ruby -w -c _filename_
実行:
ruby _filename_
結果
AC  
実行時間 131 ms / 4,000 ms
コード長 502 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 509 ms
コンパイル使用メモリ 8,704 KB
実行使用メモリ 14,848 KB
最終ジャッジ日時 2026-04-03 09:26:02
合計ジャッジ時間 4,964 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge3_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 6
other AC * 36
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #
raw source code

N, M = gets.split.map(&:to_i)
A = gets.split.map(&:to_i)

E = Hash.new { |h, k| h[k] = [] }

M.times do
  u, v = gets.split.map(&:to_i)
  E[u] << v
  E[v] << u
end

1.upto(N) do |v|
  next if E[v].size == 1
  a1 = A[v - 1]

  E[v].combination(2) do |i, j|
    a2 = A[i - 1]
    a3 = A[j - 1]
    next if a1 == a2
    next if a1 == a3
    next if a2 == a3

    if a2 < a1 && a1 > a3
      puts 'YES'
      exit
    end

    if a2 > a1 && a1 < a3
      puts 'YES'
      exit
    end
  end
end

puts 'NO'
0