結果

問題 No.355 数当てゲーム(2)
ユーザー maspymaspy
提出日時 2020-02-29 01:38:59
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
RE  
実行時間 -
コード長 1,579 bytes
コンパイル時間 74 ms
コンパイル使用メモリ 12,800 KB
実行使用メモリ 40,144 KB
平均クエリ数 1.00
最終ジャッジ日時 2024-07-16 20:32:13
合計ジャッジ時間 15,653 ms
ジャッジサーバーID
(参考情報)
judge3 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
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 -
testcase_28 RE -
testcase_29 RE -
testcase_30 RE -
testcase_31 RE -
testcase_32 RE -
testcase_33 RE -
testcase_34 RE -
testcase_35 RE -
testcase_36 RE -
testcase_37 RE -
testcase_38 RE -
testcase_39 RE -
testcase_40 RE -
testcase_41 RE -
testcase_42 RE -
testcase_43 RE -
testcase_44 RE -
testcase_45 RE -
testcase_46 RE -
testcase_47 RE -
testcase_48 RE -
testcase_49 RE -
testcase_50 RE -
testcase_51 RE -
権限があれば一括ダウンロードができます

ソースコード

diff #

#!/usr/bin/env python3
# %%
import sys
readline = sys.stdin.readline

# %%
#DEBUG = True
DEBUG = False


# %%
class Interactive:
    def __init__(self):
        self.ques_cnt = 0
        self.create_data()

    def create_data(self):
        import random
        while True:
            N = [random.randint(0, 9) for _ in range(4)]
            if len(set(N)) < 4:
                continue
            break
        self.N = N
        print('created', N)

    def resp_ques(self, *args):
        x = sum(a == b for a, b in zip(self.N, args))
        xy = len(set(self.N) & set(args))
        return f'{x} {xy-x}\n'

    def resp_ans(self, *args):
        pass


if DEBUG:
    interactive = Interactive()


def question(*args, offset=None):
    if offset is None:
        print(*args, flush=True)
    else:
        print(offset, *args, flush=True)
    if DEBUG:
        resp = interactive.resp_ques(*args)
        print(resp, end='')
        return resp
    else:
        return readline()


def answer(*args, offset=None):
    if offset is None:
        print(*args, flush=True)
    else:
        print(offset, *args, flush=True)
    if DEBUG:
        interactive.resp_ans(*args)
    else:
        exit()


# %%
def get_kth_digit(k):
    A = [0, 0, 0, 0]
    best_x = 0
    ret = 0
    for i in range(10):
        A[k] = i
        resp = question(*A)
        x, y = map(int, resp.split())
        if x == 4:
            exit()
        if best_x < x:
            best_x = x
            ret = i
    return ret


# %%
A = [get_kth_digit(k) for k in [0, 1, 2, 3]]
question(*A)
exit()
0