이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "teams.h"
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef struct item * pitem;
#define rep(a, b) for(int a = 0; a < (b); ++a)
#define st first
#define nd second
#define pb push_back
#define all(a) a.begin(), a.end()
struct item {
pitem l=nullptr, r=nullptr;
int x=0;
};
const int LIM=5e5+7;
pitem roots[LIM];
pair<int,int>T[LIM];
int n, N=1;
void build(pitem v, int l, int r) {
if(l==r) return;
v->l=new item();
v->r=new item();
int mid=(l+r)/2;
build(v->l, l, mid);
build(v->r, mid+1, r);
}
pitem upd(pitem v, int l, int r, int a) {
if(r<a || a<l) return v;
pitem x=new item();
x->x=v->x+1;
if(l==r) {
x->l=v->r;
x->r=v->r;
return x;
}
int mid=(l+r)/2;
x->l=upd(v->l, l, mid, a);
x->r=upd(v->r, mid+1, r, a);
x->x=x->l->x+x->r->x;
return x;
}
int cnt(pitem v, int l, int r, int a, int b) {
if(r<a || b<l) return 0;
if(a<=l && r<=b) return v->x;
int mid=(l+r)/2;
return cnt(v->l, l, mid, a, b)+cnt(v->r, mid+1, r, a, b);
}
int kwad(int l, int r, int a, int b) {
return cnt(roots[r+1], 0, N-1, a, b)-cnt(roots[l], 0, N-1, a, b);
}
void init(int _N, int A[], int B[]) {
n=_N;
while(N<=n) N*=2;
rep(i, n) T[i]={B[i], A[i]};
sort(T, T+n);
T[n]={n+1, 0};
roots[0]=new item();
build(roots[0], 0, N-1);
rep(i, n+1) roots[i+1]=upd(roots[i], 0, N-1, T[i].nd);
}
int znajdz(int x) {
int po=0, ko=n;
while(po<ko) {
int sr=(po+ko)/2;
if(T[sr].st<x) po=sr+1; else ko=sr;
}
return po;
}
int can(int m, int K[]) {
sort(K, K+m);
int sum=0;
rep(i, m) {
sum+=K[i];
if(sum>n) return 0;
}
vector<pair<int,int>>P;
P.pb({-1, n});
rep(i, m) {
int x=K[i], a=znajdz(K[i]);
if(a==n) return 0;
while(P.back().nd<a) P.pop_back();
while(P.size()>0) {
int c=kwad(a, P.back().nd, P.back().st+1, K[i]);
if(c>x) break;
x-=c;
a=P.back().nd+1;
P.pop_back();
}
if(P.size()==0) return 0;
int po=a, ko=n;
while(po<ko) {
int sr=(po+ko)/2;
if(kwad(a, sr, P.back().st+1, K[i])<x) po=sr+1; else ko=sr;
}
P.pb({K[i], po});
}
return 1;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |