Submission #1118525

#TimeUsernameProblemLanguageResultExecution timeMemory
1118525somefolkPassword (RMI18_password)C++17
50 / 100
1008 ms740 KiB
#include <iostream> #include <cmath> #include <algorithm> #include <string> #include <vector> #include <map> #include <unordered_map> #include <queue> #include <set> #include <unordered_set> #include <complex> #include <list> #include <chrono> #include <random> #include <stack> #include <iomanip> #include <fstream> #include <cassert> using namespace std; #define endl "\n" // #define int long long const int INF = 2 * 1e5 + 5; const int MOD = 1e9 + 7; // int query(string s){ // int n; // cout << s; // cin >> n; // return n; // } int query(string s); string guess(int n, int s){ bool pass = false; string sol = ""; for(char i = 'a'; i < 'a'+s; i++){ string letter = string(n, i); int amount = query(letter); int initAmount = amount, totalDiff = 0; if(amount == 0) continue; if(!pass){ sol += string(amount, i); pass = true; } else { int len = sol.length(); vector<pair<int, int>> add; for(int j = 0; j <= len; j++){ string curr = sol.substr(0, len-j) + string(n-(len-j), i); amount = query(curr); int pos = len - j; int diff = amount - pos - totalDiff; if(diff > 0){ add.push_back({pos, diff}); initAmount -= diff; totalDiff+=diff; if(initAmount <= 0) break; } } int k = 0; sort(add.begin(), add.end()); for(auto &j : add){ sol.insert(j.first + k, string(j.second, i)); k+=j.second; // cout << "{" << j.first << " " << j.second << "}" << endl; } // cout << "| " << sol << " |" << endl; } } assert(sol.size()==n); return sol; }

Compilation message (stderr)

In file included from /usr/include/c++/10/cassert:44,
                 from password.cpp:18:
password.cpp: In function 'std::string guess(int, int)':
password.cpp:72:22: warning: comparison of integer expressions of different signedness: 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   72 |     assert(sol.size()==n);
      |            ~~~~~~~~~~^~~
#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...