結果

問題 No.1830 Balanced Majority
ユーザー simansiman
提出日時 2022-02-05 12:45:29
言語 Ruby
(3.3.0)
結果
WA  
実行時間 -
コード長 278 bytes
コンパイル時間 51 ms
コンパイル使用メモリ 11,560 KB
実行使用メモリ 31,612 KB
平均クエリ数 13.54
最終ジャッジ日時 2023-09-02 06:35:23
合計ジャッジ時間 4,741 ms
ジャッジサーバーID
(参考情報)
judge14 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 AC 105 ms
31,320 KB
testcase_04 WA -
testcase_05 WA -
testcase_06 AC 106 ms
30,840 KB
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 AC 109 ms
31,272 KB
testcase_13 WA -
testcase_14 WA -
testcase_15 AC 110 ms
31,232 KB
testcase_16 AC 109 ms
31,316 KB
testcase_17 WA -
testcase_18 WA -
testcase_19 AC 107 ms
31,324 KB
testcase_20 AC 105 ms
31,388 KB
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
testcase_25 AC 108 ms
31,276 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

N = gets.to_i

def send_query(k)
  STDOUT.puts("? #{k}")
  STDOUT.flush

  gets.to_i
end

l = 1
r = N + 1

20.times do
  k = (l + r) / 2
  s = send_query(k)

  if k.even? && s == k / 2
    r = k
    break
  elsif s <= k / 2
    l = k
  else
    r = k
  end
end

puts "! 1 #{r}"
0