Submission #198278

#TimeUsernameProblemLanguageResultExecution timeMemory
198278alradGrudanje (COCI19_grudanje)C++17
70 / 70
489 ms17072 KiB
#include <bits/stdc++.h>

using namespace std;

int main() {
   ios_base :: sync_with_stdio(0);
   cin.tie(0) , cout.tie(0);
   string s;
   cin >> s;
   const int n = (int)s.size();
   int q;
   cin >> q;
   vector<pair<int , int> > sub(q);
   for (int i = 0; i < q; i++) {
      int a , b;
      cin >> a >> b;
      sub[i] = {a , b};
   }
   vector<int> p(n);
   for (int i = 0; i < n; i++) {
      cin >> p[i];
   }
   auto can = [&](int tot) {
      vector<bool> used(n , false);
      for (int i = 0; i < tot; i++) {
         used[p[i]] = true;
      }
      vector<vector<int> > let(n + 1 , vector<int>(26 , 0));
      for (int i = 1; i <= n; i++) {
         if (!used[i]) {
            let[i][int(s[i - 1] - 'a')]++;
         }
         for (int j = 0; j < 26; j++) {
            let[i][j] += let[i - 1][j];
         }
      }
      for (int i = 0; i < q; i++) {
         int L = sub[i].first , R = sub[i].second;
         for (int j = 0; j < 26; j++) {
            if (let[R][j] - let[L - 1][j] >= 2) {
               return false;
            }
         }
      }
      return true;
   };
   int l = 0 , r = n;
   while (l != r) {
      int mid = (l + r) >> 1;
      if (can(mid))
         r = mid;
      else
         l = mid + 1;
   }
   cout << r << '\n';
   return 0;
}
#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...
#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...