Submission #709414

#TimeUsernameProblemLanguageResultExecution timeMemory
709414salmonPassword (RMI18_password)C++14
Compilation error
0 ms0 KiB
#include <bits/stdc++.h> using namespace std; //int query(string str); string guess(int N, int S){ int t = 0; struct node{ int v; node *l,*r; node(int s){ v = s; l = NULL; r = NULL; } }*aas,*infront,*inback; aas = new node(0); string alphabet = ""; for(int i = 'a'; i < 'a' + S; i++){ alphabet.push_back(i); } inback = aas -> r; infront = aas; for(int i = 1; i <= N - 30; i++){ string temp = ""; string temp1 = ""; node *point = aas; while(point != inback){ if(point -> v == 0){ point = point -> r; } else{ temp.push_back(point -> v); point = point -> r; } } point = inback; while(point != NULL){ if(point -> v == 0){ point = point -> r; } else{ temp1.push_back(point -> v); point = point -> r; } } if(query(temp + alphabet + temp1) < i){ inback = infront; infront = infront -> l; i--; continue; } int s = 'a'; int e = 'a' + S - 1; while(s != e){ int m = (s + e)/2; string temp2 = temp; for(int i = s; i <= m; i++){ temp2.push_back(s); } temp2 = temp2 + temp1; if(query(temp2) >= i){ e = m; } else{ s = m + 1; } } node *temp3 = new node(s); infront -> r = temp3; temp3 -> l = infront; infront = temp3; inback = temp3 -> r; } for(int i = max(1,N - 29); i <= N; i++){ string temp = ""; string temp1 = ""; node *point; point = aas; while(point != inback){ if(point -> v == 0){ point = point -> r; } else{ temp.push_back(point -> v); point = point -> r; } } point = inback; while(point != NULL){ if(point -> v == 0){ point = point -> r; } else{ temp1.push_back(point -> v); point = point -> r; } } // cout << "s" + temp + " " + temp1 << endl; int s = 'a'; int e = 'a' + S - 1; string temp2; for(char j = s; j <= e; j++){ temp2 = temp; temp2.push_back(j); temp2 = temp2 + temp1; //cout << temp2 << endl; if(query(temp2) == i){ //cout << "j = " << j << endl; node *temp3 = new node(j); infront -> r = temp3; temp3 -> l = infront; infront = temp3; temp3 -> r = inback; temp = temp2; break; } } if(query(temp) < i){ inback = infront; infront = infront -> l; i--; continue; } } string temp = ""; string temp1 = ""; node *point = aas; while(point != NULL){ if(point -> v == 0){ point = point -> r; } else{ temp1.push_back(point -> v); point = point -> r; } } return temp + temp1; } /* 26 26 nabcdefghjiklmopqrstuvwxyz */

Compilation message (stderr)

password.cpp: In function 'std::string guess(int, int)':
password.cpp:58:12: error: 'query' was not declared in this scope
   58 |         if(query(temp + alphabet + temp1) < i){
      |            ^~~~~
password.cpp:79:16: error: 'query' was not declared in this scope
   79 |             if(query(temp2) >= i){
      |                ^~~~~
password.cpp:131:16: error: 'query' was not declared in this scope
  131 |             if(query(temp2) == i){
      |                ^~~~~
password.cpp:143:12: error: 'query' was not declared in this scope
  143 |         if(query(temp) < i){
      |            ^~~~~
password.cpp:7:9: warning: unused variable 't' [-Wunused-variable]
    7 |     int t = 0;
      |         ^