제출 #1052682

#제출 시각아이디문제언어결과실행 시간메모리
1052682thomas_li팀들 (IOI15_teams)C++17
100 / 100
342 ms165204 KiB
#include <bits/stdc++.h>
using namespace std;
namespace std {

template <class Fun> class y_combinator_result {
  Fun fun_;

public:
  template <class T>
  explicit y_combinator_result(T &&fun) : fun_(std::forward<T>(fun)) {}

  template <class... Args> decltype(auto) operator()(Args &&...args) {
    return fun_(std::ref(*this), std::forward<Args>(args)...);
  }
};

template <class Fun> decltype(auto) yc(Fun &&fun) {
  return y_combinator_result<std::decay_t<Fun>>(std::forward<Fun>(fun));
}

} // namespace std
typedef long long ll;
// #define int ll
#define rep(i, a, b) for (int i = a; i < (b); ++i)
#define all(x) begin(x), end(x)
#define sz(x) (int)(x).size()
#define PB push_back
#define FS first
#define SD second
#define ary(k) array<int, k>
template <class A, class B> void cmx(A &x, B y) { x = max<A>(x, y); }
template <class A, class B> void cmn(A &x, B y) { x = min<A>(x, y); }
typedef pair<int, int> pii;
typedef vector<int> vi;
const int MM = 5e5 + 5;
struct Node {
  int l, r, sum;
} seg[MM * 30];
int ti = 0;
int build(int l, int r) {
  int u = ti++;
  seg[u].sum = 0;
  if (l != r) {
    int mid = (l + r) / 2;
    seg[u].l = build(l, mid);
    seg[u].r = build(mid + 1, r);
  }
  return u;
};
int inc(int u, int l, int r, int x) {
  int nu = ti++;
  seg[nu] = seg[u];
  if (l == r) {
    seg[nu].sum++;
    return nu;
  }
  int mid = (l + r) / 2;
  if (x <= mid)
    seg[nu].l = inc(seg[nu].l, l, mid, x);
  else if (x > mid)
    seg[nu].r = inc(seg[nu].r, mid + 1, r, x);
  seg[nu].sum = seg[seg[nu].l].sum + seg[seg[nu].r].sum;
  return nu;
};
int sum(int u, int l, int r, int ql, int qr) {
  if (l == ql && r == qr)
    return seg[u].sum;
  int mid = (l + r) / 2;
  if (qr <= mid)
    return sum(seg[u].l, l, mid, ql, qr);
  else if (ql > mid)
    return sum(seg[u].r, mid + 1, r, ql, qr);
  else
    return sum(seg[u].l, l, mid, ql, mid) +
           sum(seg[u].r, mid + 1, r, mid + 1, qr);
};
int n, ver[MM];
void init(int N, int A[], int B[]) {
  n = N;
  vector<vi> ls(n + 1);
  vector<pii> in;
  rep(i, 0, n) {
    int l = A[i], r = B[i];
    ls[r].PB(l);
  }
  int root = build(1, n);
  for (int i = n; i >= 1; i--) {
    for (int l : ls[i]) {
      root = inc(root, 1, n, l);
    }
    ver[i] = root;
  }
}
int cnt[MM];
int can(int M, int K[]) {
  int m = M;
  vi vals;
  rep(i, 0, m) {
    int x = K[i];
    vals.PB(x);
    cnt[x]++;
  }
  if (accumulate(all(vals), 0ll) > n) {
    return 0;
  }
  vals.PB(0);
  sort(all(vals));
  vals.erase(unique(all(vals)), vals.end());
  vi good = {0}, goodv = {0};
  bool done = 0;
  rep(i, 1, sz(vals)) {
    int x = vals[i];
    int tot = cnt[x] * x;
    int cur = 1e9;
    rep(k, 0, sz(good)) {
      int add = sum(ver[x], 1, n, goodv[k] + 1, x) - tot;
      cmn(cur, good[k] + add);
    }
    if (cur < 0) {
      done = 1;
      break;
    }
    while (sz(good) && good.back() >= cur) {
      good.pop_back();
      goodv.pop_back();
    }
    good.PB(cur);
    goodv.PB(vals[i]);
  }
  for (int x : vals)
    cnt[x] = 0;
  return !done;
}

// delta = sumpeople - sumsizes
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...