Submission #755855

#TimeUsernameProblemLanguageResultExecution timeMemory
755855MohamedFaresNebiliPassword (RMI18_password)C++14
0 / 100
5 ms328 KiB
#include <bits/stdc++.h> using namespace std; int query(string str); string guess(int n, int s) { string S(n, 'a'); int freq[s], used[s]; for(int l = 0; l < s; l++) { used[l] = 0; for(int i = 0; i < n; i++) S[i] = char(l + 'a'); freq[l] = query(S); } S = ""; for(int l = 0; l < n; l++) { S.push_back('a'); for(int i = 0; i < s; i++) { if(used[i] == freq[i]) continue; S[l] = char(i + 'a'); if(l < n - 1) { used[i]++; int cnt = 0, tr = 0; for(int j = 0; j < s; j++) { if(used[j] == freq[j]) continue; tr++; for(int e = used[j] + 1; e <= freq[j]; e++) S.push_back(char(j + 'a')); int R = query(S); R -= l; if(R == 1 + freq[j] - used[j]) cnt++; else break; for(int e = used[j] + 1; e <= freq[j]; e++) S.pop_back(); } used[i]--; if(cnt == tr){ used[i]++; break; } } else { int K = query(S); if(K == n) break; } } } return S; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...