結果

問題 No.850 企業コンテスト2位
ユーザー convexineqconvexineq
提出日時 2019-07-05 23:28:39
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
RE  
実行時間 -
コード長 795 bytes
コンパイル時間 700 ms
コンパイル使用メモリ 10,832 KB
実行使用メモリ 24,372 KB
平均クエリ数 97.57
最終ジャッジ日時 2023-09-23 17:42:50
合計ジャッジ時間 7,231 ms
ジャッジサーバーID
(参考情報)
judge11 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
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 -
権限があれば一括ダウンロードができます

ソースコード

diff #

# coding: utf-8
# Your code here!

import sys
sys.setrecursionlimit(10**6)
readline = sys.stdin.readline #文字列入力のときは注意

n=int(input())

cand = [[i] for i in range(n)]
while len(cand) > 1:
    cand2 = []
    while len(cand) > 1:
        a = cand.pop()
        b = cand.pop()
        print("?", a[0], b[0])
        sys.stdout.flush()
        res = int(input())
        if res == a[0]:
            a.append(b[0])
            cand2.append(a)
        else:
            b.append(a[0])
            cand2.append(b)
    if cand: cand2.append(cand[0])
    cand = cand2

cand = cand[0]
cand.pop(0)

ans = cand.pop()
while cand:
    c = cand.pop()
    print("?", ans, c)
    sys.stdout.flush()
    res = int(input())
    if res == c: ans = c

print("!", ans)    
    
    
    
    



0