Submission #8665793


Source Code Expand

/**
 *    author:  tourist
 *    created: 26.11.2019 17:52:04       
**/
#include <bits/stdc++.h>

using namespace std;

int main() {
  ios::sync_with_stdio(false);
  cin.tie(0);
  int n;
  cin >> n;
  vector<int> a(n);
  for (int i = 0; i < n; i++) {
    cin >> a[i];
  }
  string s;
  cin >> s;
  int low = 1, high = n;
  while (low < high) {
    int mid = (low + high + 1) >> 1;
    vector<int> b(n);
    for (int i = 0; i < n; i++) {
      b[i] = (a[i] >= mid);
    }
    vector<int> seq(1, 1);
    for (int i = 1; i < n; i++) {
      if (b[i] != b[i - 1]) {
        seq.push_back(1);
      } else {
        seq.back() += 1;
      }
    }
    seq[0] += n;
    seq.back() += n;
    int sz = (int) seq.size();
    vector<int> what(sz);
    for (int i = 0; i < sz; i++) {
      what[i] = (b[0] + i) % 2;
    }
    vector<set<pair<int, int>>> inner(2);
    vector<int> delta(2, 0);
    for (int i = 0; i < sz; i++) {
      inner[what[i]].emplace(seq[i], i);
    }
    vector<int> pr(sz);
    vector<int> ne(sz);
    for (int i = 0; i < sz; i++) {
      pr[i] = i - 1;
      ne[i] = i + 1;
    }
    auto Remove = [&](int x) {
      if (ne[x] < sz) {
        pr[ne[x]] = pr[x];
      }
      ne[pr[x]] = ne[x];
    };
    for (char c : s) {
      int u = (c == 'm' ? 0 : 1);
      delta[u] += 1;
      delta[u ^ 1] -= 1;
      while (!inner[u ^ 1].empty() && inner[u ^ 1].begin()->first + delta[u ^ 1] == 0) {
        int me = inner[u ^ 1].begin()->second;
        inner[u ^ 1].erase(inner[u ^ 1].begin());
        inner[u].erase({seq[pr[me]], pr[me]});
        inner[u].erase({seq[ne[me]], ne[me]});
        seq[pr[me]] += seq[ne[me]] + delta[u];
        inner[u].emplace(seq[pr[me]], pr[me]);
        Remove(me);
        Remove(ne[me]);
      }
      if (what[0] == u) {
        inner[u].erase({seq[0], 0});
        seq[0] -= 1;
        inner[u].emplace(seq[0], 0);
      }
    }
    int have = 0;
    int winner = -1;
    for (int i = 0; i < sz; i = ne[i]) {
      have += seq[i] + delta[what[i]];
      if (have >= n + 1) {
        winner = what[i];
        break;
      }
    }
    if (winner == 1) {
      low = mid;
    } else {
      high = mid - 1;
    }
  }
  cout << low << '\n';
  return 0;
}

Submission Info

Submission Time
Task B - Compression
User tourist
Language C++14 (GCC 5.4.1)
Score 1400
Code Size 2300 Byte
Status AC
Exec Time 411 ms
Memory 4296 KB

Judge Result

Set Name Sample subtask1 subtask2 All
Score / Max Score 0 / 0 400 / 400 800 / 800 200 / 200
Status
AC × 4
AC × 13
AC × 13
AC × 53
Set Name Test Cases
Sample sample_1.txt, sample_2.txt, sample_3.txt, sample_4.txt
subtask1 sample_2.txt, subtask_1.2_1.txt, subtask_1.2_2.txt, subtask_1_1.txt, subtask_1_10.txt, subtask_1_2.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt
subtask2 sample_1.txt, subtask_1.2_1.txt, subtask_1.2_2.txt, subtask_2_1.txt, subtask_2_10.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt
All sample_1.txt, sample_2.txt, sample_3.txt, sample_4.txt, 2_1.txt, 2_2.txt, sample_1.txt, sample_2.txt, sample_3.txt, sample_4.txt, subtask_1.2_1.txt, subtask_1.2_2.txt, subtask_1_1.txt, subtask_1_10.txt, subtask_1_2.txt, subtask_1_3.txt, subtask_1_4.txt, subtask_1_5.txt, subtask_1_6.txt, subtask_1_7.txt, subtask_1_8.txt, subtask_1_9.txt, subtask_2_1.txt, subtask_2_10.txt, subtask_2_2.txt, subtask_2_3.txt, subtask_2_4.txt, subtask_2_5.txt, subtask_2_6.txt, subtask_2_7.txt, subtask_2_8.txt, subtask_2_9.txt, subtask_3_1.txt, subtask_3_10.txt, subtask_3_11.txt, subtask_3_12.txt, subtask_3_13.txt, subtask_3_14.txt, subtask_3_15.txt, subtask_3_16.txt, subtask_3_17.txt, subtask_3_18.txt, subtask_3_19.txt, subtask_3_2.txt, subtask_3_20.txt, subtask_3_21.txt, subtask_3_3.txt, subtask_3_4.txt, subtask_3_5.txt, subtask_3_6.txt, subtask_3_7.txt, subtask_3_8.txt, subtask_3_9.txt
Case Name Status Exec Time Memory
2_1.txt AC 1 ms 256 KB
2_2.txt AC 1 ms 256 KB
sample_1.txt AC 1 ms 256 KB
sample_2.txt AC 1 ms 256 KB
sample_3.txt AC 1 ms 256 KB
sample_4.txt AC 1 ms 256 KB
subtask_1.2_1.txt AC 1 ms 256 KB
subtask_1.2_2.txt AC 1 ms 256 KB
subtask_1_1.txt AC 164 ms 4296 KB
subtask_1_10.txt AC 123 ms 4296 KB
subtask_1_2.txt AC 91 ms 4296 KB
subtask_1_3.txt AC 77 ms 4296 KB
subtask_1_4.txt AC 91 ms 3836 KB
subtask_1_5.txt AC 23 ms 768 KB
subtask_1_6.txt AC 137 ms 4296 KB
subtask_1_7.txt AC 1 ms 256 KB
subtask_1_8.txt AC 129 ms 4296 KB
subtask_1_9.txt AC 123 ms 4296 KB
subtask_2_1.txt AC 310 ms 4296 KB
subtask_2_10.txt AC 293 ms 4296 KB
subtask_2_2.txt AC 177 ms 4296 KB
subtask_2_3.txt AC 306 ms 4296 KB
subtask_2_4.txt AC 169 ms 4296 KB
subtask_2_5.txt AC 1 ms 256 KB
subtask_2_6.txt AC 1 ms 256 KB
subtask_2_7.txt AC 1 ms 256 KB
subtask_2_8.txt AC 316 ms 4220 KB
subtask_2_9.txt AC 36 ms 1280 KB
subtask_3_1.txt AC 411 ms 4296 KB
subtask_3_10.txt AC 273 ms 4296 KB
subtask_3_11.txt AC 408 ms 4296 KB
subtask_3_12.txt AC 97 ms 4296 KB
subtask_3_13.txt AC 100 ms 4296 KB
subtask_3_14.txt AC 107 ms 4296 KB
subtask_3_15.txt AC 94 ms 4296 KB
subtask_3_16.txt AC 91 ms 4296 KB
subtask_3_17.txt AC 92 ms 4296 KB
subtask_3_18.txt AC 88 ms 4296 KB
subtask_3_19.txt AC 100 ms 4296 KB
subtask_3_2.txt AC 303 ms 4296 KB
subtask_3_20.txt AC 100 ms 4296 KB
subtask_3_21.txt AC 100 ms 4296 KB
subtask_3_3.txt AC 37 ms 792 KB
subtask_3_4.txt AC 346 ms 3836 KB
subtask_3_5.txt AC 305 ms 3480 KB
subtask_3_6.txt AC 346 ms 4296 KB
subtask_3_7.txt AC 269 ms 4296 KB
subtask_3_8.txt AC 277 ms 4296 KB
subtask_3_9.txt AC 178 ms 4296 KB