#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
typedef long long ll;
using namespace __gnu_pbds;
using namespace std;
template <typename T>
using ordered_set = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>;
int query(string str);
int N;
string Merge(string s1, string s2) {
string res = s1; int ins=0;
for(auto c : s2) {
while(1) {
string zap="";
for(int i=0; i<=res.size(); ++i) {
if(i==ins) zap.push_back(c);
if(i<res.size()) zap.push_back(res[i]);
}
if(query(zap)==zap.size()) {
ins++; res = zap;
break;
} else ins++;
}
}
return res;
}
string MergeSort(vector<string> t) {
if(t.size()==0) return "";
if(t.size()==1) return t[0];
vector<string> t1, t2;
int n =t.size();
for(int i=0; i<n/2; ++i) t1.push_back(t[i]);
for(int i=n/2; i<n; ++i) t2.push_back(t[i]);
return Merge(MergeSort(t1),MergeSort(t2));
}
string pwt(char c, int x) {
string s = "";
for(int i=0; i<x; ++i) s.push_back(c);
return s;
}
string guess(int n, int S) {
N=n;
string alph = "abcdefghijklmnopqrstuvwxyz";
vector<string> tab;
for(int i=0; i<S; ++i) {
tab.push_back(pwt(alph[i], query(pwt(alph[i],n))));
}
return MergeSort(tab);
}
| # | 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... |