結果

問題 No.1369 交換門松列・竹
ユーザー maimai
提出日時 2019-09-30 03:39:17
言語 Ruby
(3.3.0)
結果
RE  
実行時間 -
コード長 871 bytes
コンパイル時間 195 ms
コンパイル使用メモリ 11,436 KB
実行使用メモリ 15,776 KB
最終ジャッジ日時 2023-09-29 15:04:31
合計ジャッジ時間 4,122 ms
ジャッジサーバーID
(参考情報)
judge11 / judge15
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 RE -
testcase_01 RE -
testcase_02 RE -
testcase_03 RE -
testcase_04 RE -
testcase_05 RE -
testcase_06 RE -
testcase_07 RE -
testcase_08 RE -
testcase_09 RE -
testcase_10 RE -
testcase_11 RE -
testcase_12 RE -
testcase_13 RE -
testcase_14 RE -
testcase_15 RE -
testcase_16 RE -
testcase_17 RE -
testcase_18 RE -
testcase_19 RE -
testcase_20 RE -
testcase_21 RE -
testcase_22 RE -
testcase_23 RE -
testcase_24 RE -
testcase_25 RE -
testcase_26 RE -
testcase_27 RE -
testcase_28 RE -
testcase_29 RE -
testcase_30 RE -
testcase_31 RE -
testcase_32 RE -
testcase_33 RE -
権限があれば一括ダウンロードができます
コンパイルメッセージ
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

validate_idxs = not_kado_idxs.map{|i| (-2..2).map{|e|i+e}.to_a}.flatten.uniq.select{|i| 0 <= i && i <= n}

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 ||= validate_idxs.each.all?{|i| 🎍(arr[i], arr[i+1], arr[i+2])}
            arr[i], arr[j] = arr[j], arr[i]
        end
    end
end

puts ok ? 'Yes' : 'No'
0