# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
643134 | TimDee | Password (RMI18_password) | C++17 | 5 ms | 336 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
int query(string s);
string guess(int n, int c) {
if (c==2) {
string A(n,'a'), B(n,'b');
int a=query(A),b=query(B);
string ans;
int added=0;
for (int i=a; i>=0; --i) {
string s;
for (int j=0; j<i; ++j) s+='a';
for (int j=i; j<n; ++j) s+='b';
int x=query(s);
for (int j=0; j<x-added-i; ++j) ans+='b';
ans+='a';
added=x-i;
}
ans.pop_back();
reverse(ans.begin(), ans.end());
return ans;
}
if (c==3) {
string A(n,'a'), B(n,'b'), C(n,'c');
int a=query(A),b=query(B),c=query(C);
string ans;
int addedb=0,addedc=0;
for (int i=a; i>=0; --i) {
string s;
for (int j=0; j<i; ++j) s+='a';
for (int j=i; j<n; ++j) s+='b';
int x=query(s)-i-addedb;
s.clear();
for (int j=0; j<i; ++j) s+='a';
for (int j=i; j<n; ++j) s+='c';
int y=query(s)-i-addedc;
string tmp(i,'a');
int added=0;
cout<<x<<' '<<y<<'\n';
if (y) {
for (int j=x; j>=0; --j) {
string s=tmp;
for (int k=0; k<j; ++k) s+='b';
for (int k=0; k<y; ++k) s+='c';
int v=query(s)-i-j-added;
for (int k=0; k<v; ++k) {
ans+='c'; addedc++; added++;
}
ans+='b';
addedb++;
}
ans.pop_back(); --addedb;
}
else for(int k=0; k<x; ++k) {ans+='b'; addedb++;}
ans.push_back('a');
}
ans.pop_back();
reverse(ans.begin(), ans.end());
return ans;
}
if (n<=c && c<=26) {
string ans(n,'.');
for (char i='a'; i<'a'+c; ++i) {
int x=0;
for (char j='a'; j<'a'+c; ++j) {
if (j==i) continue;
string s;
s+=i; s+=j;
int q=query(s);
x+=q-1;
}
if (x<0) continue;
ans[n-1-x]=i;
}
int paiu=1;
for (auto x:ans) paiu&=x!='.';
if (paiu) return ans;
}
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |