結果

問題 No.2124 Guess the Permutation
コンテスト
ユーザー siman
提出日時 2022-11-18 21:46:53
言語 Ruby
(4.0.2)
コンパイル:
ruby -w -c _filename_
実行:
ruby _filename_
結果
AC  
実行時間 84 ms / 2,000 ms
コード長 404 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 123 ms
コンパイル使用メモリ 8,960 KB
実行使用メモリ 34,720 KB
平均クエリ数 374.60
最終ジャッジ日時 2026-04-08 14:37:39
合計ジャッジ時間 2,105 ms
ジャッジサーバーID
(参考情報)
judge2_1 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 9
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #
raw source code

N = gets.to_i
sum = (1..N).sum

def send_query(l, r)
  STDOUT.puts("? #{l} #{r}")
  STDOUT.flush

  gets.to_i
end

arr = []

(N - 1).times do |i|
  if i == N - 2
    res = send_query(2, N)
    s = (1..N).sum - res
    sum -= s
    arr << sum
    arr << s
  else
    res = send_query(1, N - i - 1)

    arr << sum - res
    sum -= arr.last
  end
end

STDOUT.puts("! #{arr.reverse.join(' ')}")
STDOUT.puts
0