結果

問題 No.2768 Password Crack
ユーザー kusaf_kusaf_
提出日時 2024-06-04 01:16:29
言語 C++23
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 102 ms / 2,000 ms
コード長 635 bytes
コンパイル時間 3,048 ms
コンパイル使用メモリ 245,232 KB
実行使用メモリ 25,220 KB
平均クエリ数 885.00
最終ジャッジ日時 2024-12-23 10:45:41
合計ジャッジ時間 6,579 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 29
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
using ll = long long;

int main() {
  ios::sync_with_stdio(false);
  cin.tie(nullptr);

  ll N;
  cin >> N;

  auto ask = [&](string &s) {
    cout << "? " << s << endl;
    ll x;
    cin >> x;
    return x;
  };

  string S(N, 'a'), ans = "";
  ll c = ask(S);
  for(ll i = 0; i < N; i++) {
    for(char j = 'b'; j < 'z'; j++) {
      S[i] = j;
      ll t = ask(S);
      if(t < c) {
        ans += 'a';
        break;
      }
      if(t > c) {
        ans += j;
        break;
      }
    }
    if(ans.size() != i + 1) { ans += 'z'; }
    S[i] = 'a';
  }

  cout << "! " << ans << "\n";
}
0