結果
| 問題 | No.305 鍵(2) |
| コンテスト | |
| ユーザー |
はむ吉🐹
|
| 提出日時 | 2016-03-12 18:17:13 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 54 ms / 2,000 ms |
| コード長 | 1,262 bytes |
| コンパイル時間 | 242 ms |
| コンパイル使用メモリ | 12,800 KB |
| 実行使用メモリ | 27,608 KB |
| 平均クエリ数 | 52.00 |
| 最終ジャッジ日時 | 2024-07-16 23:05:05 |
| 合計ジャッジ時間 | 1,902 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 13 |
ソースコード
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import array
import collections
import sys
MAX_D = 10
Status = collections.namedtuple("Status", "digits, status")
def submit_guess(guess_sequence):
def array_to_int(sequence):
tens = (10 ** k for k in range(MAX_D)[::-1])
return sum(x * y for x, y in zip(sequence, tens))
print("{:0=10d}".format(array_to_int(guess_sequence)))
sys.stdout.flush()
d, s = input().split()
return Status(int(d), s == "unlocked")
def main():
guess_sequence = array.array("B", (0 for _ in range(MAX_D)))
prev_digits, prev_status = submit_guess(guess_sequence)
digits, status = prev_digits, prev_status
if status:
return
for place in range(MAX_D)[::-1]:
for digit in range(10):
guess_sequence[place] = digit
digits, status = submit_guess(guess_sequence)
if status:
return
elif prev_digits < digits:
prev_digits = digits
break
elif prev_digits > digits:
guess_sequence[place] = max(digit - 1, 0)
digits = prev_digits
break
else:
continue
if __name__ == '__main__':
main()
はむ吉🐹