当前位置: 代码迷 >> 综合 >> zoj-1610-Count the Colors-线段树-区域更新,单点查询
  详细解决方案

zoj-1610-Count the Colors-线段树-区域更新,单点查询

热度:58   发布时间:2023-12-19 10:37:33.0
线段树的区域更新,然后单点查询。

x1 x2 c:区域更新x1-x2为c。

全部染色之后,从0-8000依次查询每个点的颜色。然后存贮每一种颜色有几块。

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<math.h>
using namespace std;
#define lmin 0
#define rmax 8000
#define lson l,(l+r)/2,rt<<1
#define rson (l+r)/2+1,r,rt<<1|1
#define root lmin,rmax,1
#define maxn 10000
int cl[maxn*4];
int num[maxn];
void push_up(int rt)
{}
void push_down(int rt)
{if(cl[rt]!=-1){cl[rt<<1]=cl[rt];cl[rt<<1|1]=cl[rt];cl[rt]=-1;}
}
void update(int ll,int rr,int x,int l,int r,int rt)
{if(l>rr||r<ll)return;if(ll<=l&&rr>=r){//  cout<<l<<"-"<<r<<"-"<<rt<<"-"<<x<<endl;cl[rt]=x;return;}push_down(rt);update(ll,rr,x,lson);update(ll,rr,x,rson);
}
int query(int st,int l,int r,int rt)
{if(r<st)return 0;if(l>st)return 0;if(l==r&&st==l)return cl[rt];if(l<=st&&r>=st&&cl[rt]!=-1)return cl[rt];return query(st,lson)+query(st,rson);
}
int main()
{int n,l,r,c;while(~scanf("%d",&n)){memset(cl,-1,sizeof(cl));memset(num,0,sizeof(num));while(n--){scanf("%d%d%d",&l,&r,&c);update(l,r-1,c,root);}int y=-1;for(int i=0;i<=8000;i++){int x=query(i,root);//cout<<x<<"-"<<endl;// getchar();if(x==y)continue;y=x;if(x>=0)num[x]++;}for(int i=0;i<=8000;i++){if(num[i]){printf("%d %d\n",i,num[i]);}}cout<<endl;}return 0;
}


  相关解决方案