Submission #557469

#TimeUsernameProblemLanguageResultExecution timeMemory
557469FatihSolakPassword (RMI18_password)C++17
40 / 100
73 ms17940 KiB
#include <bits/stdc++.h> using namespace std; int query(string str); // string password; // int query(string q) { // int len = q.size(); // int i = 0, j = 0, plen = password.size(); // while (i < plen && j < len) { // while ((i < plen) && (password[i] != q[j])) { // i++; // } // if (i < plen) { // i++; // j++; // } // } // return j; // } int rem[30][30][5005]; int tot = 50000; int myquery(string &s){ assert(tot--); return query(s); } int ask(int a,int b,int c,int d){ if(rem[a][b][c] != -1)return rem[a][b][c]; string tmp = ""; for(int i = 0;i<c;i++) tmp += a + 'a'; for(int i = 0;i<d;i++) tmp += b + 'a'; return rem[a][b][c] = myquery(tmp); } int ask2(int a,int b,int c,int d){ return rem[a][b][c]; } string guess(int n, int s){ for(int i = 0;i<30;i++){ for(int j = 0;j<30;j++){ for(int c = 0;c<5005;c++){ rem[i][j][c] = -1; } } } vector<int> v; for(int i = 0;i<s;i++){ v.push_back(i); } vector<int> cnt(s); vector<int> used(s); vector<int> init(s); for(int i = 0;i<s;i++){ cnt[v[i]] = ask(v[i],0,n,0); init[v[i]] = cnt[v[i]]; } string res = ""; for(int x = n-1;x>=0;x--){ vector<bool> ok(s); for(int i = 0;i<s;i++){ for(int j = 0;j<s;j++){ if(i == j)continue; if(ask2(v[i],v[j],cnt[v[i]],init[v[j]]) >= cnt[v[i]] + used[v[j]] + 1){ ok[i] = 1; } } } int val = 0; while(cnt[v[val]] == 0 || ok[val]) val++; for(int i = val+1;i<s;i++){ if(cnt[v[i]] == 0 || ok[i])continue; if(ask(v[val],v[i],cnt[v[val]],init[v[i]]) >= cnt[v[val]] + used[v[i]] + 1){ val = i; } } res += v[val] + 'a'; used[v[val]]++; cnt[v[val]]--; vector<int> tmp; for(int i = 0;i<val;i++){ tmp.push_back(v[i]); } for(int i = val+1;i<v.size();i++){ tmp.push_back(v[i]); } tmp.push_back(v[val]); v = tmp; //cout << val << endl; //cout << res << endl; } reverse(res.begin(),res.end()); return res; } // int main(){ // #ifdef Local // freopen("in.txt","r",stdin); // freopen("out.txt","w",stdout); // #endif // int n,s; // cin >> n >> s; // cin >> password; // guess(n,s); // }

Compilation message (stderr)

password.cpp: In function 'std::string guess(int, int)':
password.cpp:83:28: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   83 |         for(int i = val+1;i<v.size();i++){
      |                           ~^~~~~~~~~
#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...