結果

問題 No.2124 Guess the Permutation
ユーザー simansiman
提出日時 2022-11-18 21:46:53
言語 Ruby
(3.3.0)
結果
AC  
実行時間 147 ms / 2,000 ms
コード長 404 bytes
コンパイル時間 60 ms
コンパイル使用メモリ 11,916 KB
実行使用メモリ 32,416 KB
平均クエリ数 374.60
最終ジャッジ日時 2023-10-20 06:33:45
合計ジャッジ時間 2,395 ms
ジャッジサーバーID
(参考情報)
judge11 / judge12
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 119 ms
32,412 KB
testcase_01 AC 107 ms
32,412 KB
testcase_02 AC 107 ms
32,412 KB
testcase_03 AC 108 ms
32,412 KB
testcase_04 AC 108 ms
32,412 KB
testcase_05 AC 111 ms
32,412 KB
testcase_06 AC 127 ms
32,412 KB
testcase_07 AC 143 ms
32,412 KB
testcase_08 AC 146 ms
32,416 KB
testcase_09 AC 147 ms
32,412 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

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