結果

問題 No.1369 交換門松列・竹
ユーザー mai
提出日時 2019-09-30 02:51:23
言語 Ruby
(3.4.1)
結果
RE  
実行時間 -
コード長 738 bytes
コンパイル時間 144 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 12,672 KB
最終ジャッジ日時 2024-07-22 09:15:46
合計ジャッジ時間 4,348 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample RE * 1
other RE * 33
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

def 🎍(a,b,c)
    a != c && ((a < b && b > c) || (a > b && b < c))
end

line1 = gets.chomp!
line2 = gets.chomp!
abort if gets

n = line1.to_i
arr = line2.split.map(&:to_i)

abort 'a' if arr.find{|a| 1 > a || a > n}
abort '🎍' if arr.each_cons(3).all?{|a| 🎍(*a)}

# - - - - -

not_kado_idxs = arr.each_cons(3).each_with_index.map{|a,i| 🎍(*a) ? nil : i}.compact

if not_kado_idxs.size > 20
    puts 'No'
end

ok = false
n.times do |i|
    not_kado_idxs.each do |ji|
        3.times do |jj|
            j = ji+jj
            next if i == j
            arr[i], arr[j] = arr[j], arr[i]
            ok ||= arr.each_cons(3).all?{|a| 🎍(*a)}
            arr[i], arr[j] = arr[j], arr[i]
        end
    end
end

puts ok ? 'Yes' : 'No'
0