-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCQD.cpp
40 lines (40 loc) · 1.18 KB
/
CQD.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1e5+5;
struct NODE{
int a,b,c,cnt;
}a[maxn],b[maxn];
int tree[maxn*2];
inline void update(int x,int d){for(int i=x;i<2*maxn;tree[i]+=d,i+=i&-i);}
inline int query(int x){int ans=0;for(int i=x;i;ans+=tree[i],i-=i&-i); return ans;}
bool cmp(NODE a,NODE b){
return a.a==b.a?a.b==b.b?a.c<b.c:a.b<b.b:a.a<b.a;
}
void CDQ(int l,int r){
if(l==r) return;
int mid=l+r>>1,nl=l,nr=mid+1;CDQ(l,mid);CDQ(mid+1,r);
for(int i=l;i<=r;i++){
if((nl<=mid&&a[nl].b<=a[nr].b)||(nr>r)) update(a[nl].c,1),b[i]=a[nl++];
else a[nr].cnt+=query(a[nr].c),b[i]=a[nr++];
}
for(int i=l;i<=mid;i++) update(a[i].c,-1);
for(int i=l;i<=r;i++) a[i]=b[i];
}
inline bool same(NODE a,NODE b){
return a.a==b.a&&a.b==b.b&&a.c==b.c;
}
int cnt[2*maxn];
int main() {
int n,k,now=0;cin>>n>>k;
for(int i=1;i<=n;i++) {scanf("%d%d%d",&a[i].a,&a[i].b,&a[i].c);}
sort(a+1,a+1+n,cmp);
for(int i=n-1;i>=1;i--){
if(same(a[i],a[i+1])) {now++;a[i].cnt+=now;}
else now=0;
}
CDQ(1,n);
for(int i=1;i<=n;i++) cnt[a[i].cnt]++;
for(int i=0;i<n;i++) printf("%d\n",cnt[i]);
return 0;
}