题意:

给一个固定长度为L的画板

有两个操作:

C A B C:区间AB内涂上颜色C。

P A B:查询区间AB内颜色种类数。

分析:显然是要用线段树来操作的,设定一个sum[]来维护一个区间内的颜色,若为-1,则说明不是叶子节点,还应在往底下找;

同时在查询时维护一个vis[]来记录在这个区间内哪个颜色被使用过了。

#include<cstdio>
#include<iostream>
#include<cstring>
#define lson l,m,now*2
#define rson m+1,r,now*2+1
#define M 400010
#define N 35
using namespace std;
int vis[N],sum[M];//当sum[i]=-1是,说明不是底下至少有2种颜色,否则sum[i]是i的颜色
void build(int l,int r,int now)
{
sum[now]=;
if(l==r)return;
int m=(l+r)/;
build(lson);
build(rson);
}
void push_down(int now)
{
sum[now*]=sum[now];
sum[now*+]=sum[now];
sum[now]=-;
}
void change(int x,int y,int v,int l,int r,int now)
{
if(l>=x&&r<=y)
{
sum[now]=v;
return;
}
if(sum[now]==v)return;
if(sum[now]!=-)push_down(now);
int m=(l+r)/;
if(x<=m)change(x,y,v,lson);
if(y>m)change(x,y,v,rson);
}
void query(int x,int y,int l,int r,int now)
{
if(sum[now]!=-)
{
vis[sum[now]]=;
return;
}
int m=(l+r)/;
if(x<=m)query(x,y,lson);
if(y>m)query(x,y,rson);
}
int main()
{
int n,m,p;
scanf("%d%d%d",&n,&m,&p);
build(,n,);
for(int i=;i<=p;i++)
{
char c;
cin>>c;
if(c=='C')
{
int a,b,v;
scanf("%d%d%d",&a,&b,&v);
if(a>b)swap(a,b);
change(a,b,v,,n,);
}
else
{
memset(vis,,sizeof(vis));
int a,b,tot=;
scanf("%d%d",&a,&b);
if(a>b)swap(a,b);
query(a,b,,n,);
for(int i=;i<=;i++)
if(vis[i])tot++;
printf("%d\n",tot);
}
}
return ;
}

最新文章

  1. iOS 键盘添加完成按钮,delegate和block回调
  2. 纯CSS3制作超级漂亮又实用的加载小图标
  3. jQuery1.9之后使用on()绑定 动态生成元素的 事件无效
  4. JS学习总结(新手)
  5. Foundation -----&gt;NSArray
  6. [No000060]冷读热读:读书九问
  7. Ajax请求接口加密研究(针对网页前端的接口安全加密机制研究)
  8. powershell脚本闪电输入神器
  9. Android之Camera控制拍照
  10. 使用PF_PACKET和SOCK_RAW发送自己定义type以太网数据包
  11. loadrunner破解方法--lm70.dll,mlr5lprg.dll下载地址
  12. HUST 1354 Rubiks
  13. libcurl模拟登录CSDN并自动评论资源以获取积分
  14. A manager is becoming more and more popular in China
  15. C语言在linux内核中do while(0)妙用之法
  16. 【重学计算机】机组D4章:存储系统
  17. database锁实现
  18. 解决VS2010连接VSS时,Access to file&quot;\\***\rights.dat&quot; denied
  19. hdu 1728 逃离迷宫 bfs记转向
  20. Linux下的/proc目录介绍

热门文章

  1. 与Java Web Service相关的若干概念(JAX-WS,JAX-RS)
  2. myeclipse 引入jar包 (包括 jdbc 驱动引用)
  3. Android 使用Parcelable序列化对象
  4. json 数据交换格式与java
  5. KVM切换声音关闭
  6. mysql 索引 详解
  7. ajax局部更新
  8. 如何在eclipse中使用XYLayout布局?在此介绍如何把XYLayout导入到eclipse .
  9. 修改linux文件权限命令:chmod
  10. Web SQL数据库