Submission #1157831

#TimeUsernameProblemLanguageResultExecution timeMemory
1157831fryingducTeam Contest (JOI22_team)C++20
100 / 100
73 ms9028 KiB
#include "bits/stdc++.h"
using namespace std;

#ifdef duc_debug
#include "bits/debug.h"
#else
#define debug(...)
#endif

const int maxn = 150005;
int n;
struct contestant {
  int x, y, z;
} a[maxn];
int ord[maxn];

void solve() {
  cin >> n;
  for (int i = 1; i <= n; ++i) {
    cin >> a[i].x >> a[i].y >> a[i].z;
  }
  sort(a + 1, a + n + 1, [](const contestant &x, const contestant &y) -> bool {
    return x.x < y.x;
  });
  int res = -1;
  int y = 0, z = 0;
  set<pair<int, int>> s;
  for (int i = 1; i <= n; ++i) {
    int cur = 0;
    while (i + cur <= n and a[i].x == a[i + cur].x) {
      ++cur;
      continue;
    }
    for (int j = i; j < i + cur; ++j) {
      if (y > a[j].y and z > a[j].z) {
        res = max(res, y + z + a[j].x);
      }
    }
    for (int j = i; j < i + cur; ++j) {
      auto it = s.lower_bound(make_pair(a[j].y + 1, 0));
      while (it != s.end()) {
        if (it->second >= a[j].z) {
          break;
        }
        y = max(y, it->first);
        z = max(z, it->second);
        it = s.erase(it);
      }
      it = s.lower_bound(make_pair(a[j].y, 0));
      while (it != s.begin()) {
        it--;
        if (it->second <= a[j].z) {
          break;
        }
        y = max(y, it->first);
        z = max(z, it->second);
        it = s.erase(it);
      }
      if (a[j].y < y || a[j].z < z) {
        y = max(a[j].y, y);
        z = max(a[j].z, z);
      } else {
        s.insert(make_pair(a[j].y, a[j].z));
      }
    }
    i = i + cur - 1;
  }
  cout << res;
}
signed main() {
  ios_base::sync_with_stdio(0);
  cin.tie(0);

  solve();

  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...