zoj 1610 Count the Colors(线段…
2013-04-23 09:24
381 查看
题意:给一块长8000米的板上色 问最后能看见几种颜色 而每种颜色的几段
思路:线段树。这道题有很多细节
eg: 0 2 1
3 4 1
output 应该是 1 2 因为中间隔了一段空的
具体见代码
#include <stdio.h>
#include <string.h>
#define M 8005
#define L(x) (x<<1)
#define R(x) ((x<<1)+1)
struct data
{
int
l,r,col;
//col 等于 -1 表示什么色都没有
}node[M*3];
int
color[M];
//记录每块板上的是什么颜色
void BuildTree(int left,int right,int u)
{
node[u].l =
left;
node[u].r =
right;
node[u].col
= -1;
if (left ==
right)
return ;
int mid =
(left + right)>>1;
BuildTree(left,mid,L(u));
BuildTree(mid+1,right,R(u));
}
void getdown(int u)
{
node[L(u)].col = node[u].col;
node[R(u)].col = node[u].col;
node[u].col
= -1;
}
void updata (int left,int right,int val,int u)
{
if
(node[u].col == val)
return ;
if (left
<=
node[u].l&&node[u].r
<= right)
{
node[u].col = val;
return ;
}
if
(node[u].col !=
-1)
//延迟覆盖 不然可能会TLE(最近做一直都是延迟覆盖)
getdown (u);
int mid =
(node[u].l+ node[u].r)>>1;
if (right
<= mid)
updata (left,right,val,L(u));
else if
(left >= mid+1)
updata (left,right,val,R(u));
else
{
updata (left,right,val,L(u));
updata (left,right,val,R(u));
}
if
((node[L(u)].col ==
node[R(u)].col)&&node[L(u)].col !=
-1) //递归回来修改父结点颜色
node[u].col = node[L(u)].col;
}
void query (int u)
{
if
(node[u].col != -1)
{
for (int i = node[u].l;i <= node[u].r;i ++)
color[i] = node[u].col;
return ;
}
if
(node[u].l == node[u].r)
//这是不加这个竟然会运行不起来
return ;
query
(L(u));
query
(R(u));
}
void ans ()
{
int
res[M];
memset
(res,0,sizeof(res));
int pre =
-1,i;
for (i = 0;i
< M;i ++)
if (pre != color[i]) //颜色块不相连就++
{
pre = color[i];
res[pre] ++;
}
for (i = 0;i
< M;i ++)
if (res[i] !=0)
printf ("%d %d\n",i,res[i]);
printf
("\n");
}
int main ()
{
int
n,x,y,val;
while
(~scanf ("%d",&n))
{
memset (color,-1,sizeof (color));
BuildTree(0,M,1);
while (n --)
{
scanf
("%d%d%d",&x,&y,&val);
if (x == y)
continue;
updata (x,y-1,val,1);
//后面一个不涂就能避免那种情况
}
query (1);
ans();
}
return
0;
}
思路:线段树。这道题有很多细节
eg: 0 2 1
3 4 1
output 应该是 1 2 因为中间隔了一段空的
具体见代码
#include <stdio.h>
#include <string.h>
#define M 8005
#define L(x) (x<<1)
#define R(x) ((x<<1)+1)
struct data
{
int
l,r,col;
//col 等于 -1 表示什么色都没有
}node[M*3];
int
color[M];
//记录每块板上的是什么颜色
void BuildTree(int left,int right,int u)
{
node[u].l =
left;
node[u].r =
right;
node[u].col
= -1;
if (left ==
right)
return ;
int mid =
(left + right)>>1;
BuildTree(left,mid,L(u));
BuildTree(mid+1,right,R(u));
}
void getdown(int u)
{
node[L(u)].col = node[u].col;
node[R(u)].col = node[u].col;
node[u].col
= -1;
}
void updata (int left,int right,int val,int u)
{
if
(node[u].col == val)
return ;
if (left
<=
node[u].l&&node[u].r
<= right)
{
node[u].col = val;
return ;
}
if
(node[u].col !=
-1)
//延迟覆盖 不然可能会TLE(最近做一直都是延迟覆盖)
getdown (u);
int mid =
(node[u].l+ node[u].r)>>1;
if (right
<= mid)
updata (left,right,val,L(u));
else if
(left >= mid+1)
updata (left,right,val,R(u));
else
{
updata (left,right,val,L(u));
updata (left,right,val,R(u));
}
if
((node[L(u)].col ==
node[R(u)].col)&&node[L(u)].col !=
-1) //递归回来修改父结点颜色
node[u].col = node[L(u)].col;
}
void query (int u)
{
if
(node[u].col != -1)
{
for (int i = node[u].l;i <= node[u].r;i ++)
color[i] = node[u].col;
return ;
}
if
(node[u].l == node[u].r)
//这是不加这个竟然会运行不起来
return ;
query
(L(u));
query
(R(u));
}
void ans ()
{
int
res[M];
memset
(res,0,sizeof(res));
int pre =
-1,i;
for (i = 0;i
< M;i ++)
if (pre != color[i]) //颜色块不相连就++
{
pre = color[i];
res[pre] ++;
}
for (i = 0;i
< M;i ++)
if (res[i] !=0)
printf ("%d %d\n",i,res[i]);
printf
("\n");
}
int main ()
{
int
n,x,y,val;
while
(~scanf ("%d",&n))
{
memset (color,-1,sizeof (color));
BuildTree(0,M,1);
while (n --)
{
scanf
("%d%d%d",&x,&y,&val);
if (x == y)
continue;
updata (x,y-1,val,1);
//后面一个不涂就能避免那种情况
}
query (1);
ans();
}
return
0;
}
相关文章推荐
- 【线段树区间更新 && 染色】ZOJ - 1610 Count the Colors
- ZOJ 1610 Count the Colors(线段覆盖着色:离散化)
- 【ZOJ】1610 Count the Colors(线段树查找隔断的线段)
- Count the Colors (ZOJ_1610) 线段树 + 线段统计
- ZOJ - 1610 Count the Colors(区间更新)
- zoj 1610 Count the Colors(线段树 区间更新)
- ZOJ->Count the Colors
- Zoj 1610 Count the Colors 详细题解(区间染色,求染色段)
- zoj 1610 Count the Colors
- zoj 1610 Count the Colors
- ZOJ-1610- Count the Colors(端点染色,Lazy算法)
- ZOJ 1610 Count the Colors(线段树——区间更新)(成段染色)
- ZOJ 1610 Count the Colors
- ZOJ 1610 Count the Colors 线段树 成段更新 单点求值
- Count the Colors ZOJ - 1610
- ZOJ 1610 Count the Colors(线段树,区间覆盖,单点查询)
- ZOJ-1610 Count the Colors ( 线段树 )
- ZOJ 1610 Count the Colors 线段树 染色问题
- zoj 1610 Count the Colors
- ZOJ 1610 Count the Colors (线段树:区间染色set,整体查询)