結果

問題 No.2740 Old Maid
ユーザー tufusa
提出日時 2025-04-17 18:20:32
言語 Ruby
(3.4.1)
結果
AC  
実行時間 430 ms / 2,000 ms
コード長 468 bytes
コンパイル時間 637 ms
コンパイル使用メモリ 8,224 KB
実行使用メモリ 40,824 KB
最終ジャッジ日時 2025-04-17 18:20:51
合計ジャッジ時間 18,635 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 62
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

n = gets.to_i
ps = gets.split.map(&:to_i)
q = []

pos = ps.map.with_index { [_1, _2] }.sort_by { _1[0] }.map { _1[1] }
pre = (0...(n - 1)).to_a.tap { _1.unshift nil }
nxt = (1..n).to_a.tap { _1[-1] = nil }

n.times do |i|
  now = pos[i]
  nx = nxt[now]
  next if ps[now].nil? || nx.nil? || ps[nx].nil?

  q.push ps[now], ps[nx]
  ps[now] = ps[nx] = nil
  nxt[pre[now]] = nxt[nx] unless pre[now].nil?
  pre[nxt[nx]] = pre[now] unless nxt[nx].nil?
end

puts q.join "\s"
0