【学术篇】luogu1558&&poj2777 色板游戏
题目の传送门:
luogu:https://www.luogu.org/problem/show?pid=1558
poj:http://poj.org/problem?id=2777
题目大意:给有个长度为L的区间,支持区间染色和区间查询颜色数。
非常水的线段树。一眼看出,然后30min AC(尽管我luogu上交了四遍)(我太辣鸡了orz)
这里我们显然可以状态压缩。用(1 << x) 不过要记住初始颜色1的值要设为2(1<<1)就因为这个我WA了两遍。。(然后又因为线段树忘了开四倍RE了一遍)
然后区间覆盖直接打标记覆盖就好,区间查询的话用到了神奇的or运算,把他们全or起来就是一个数了,然后统计这个数中1的个数即可。。
统计1的时候,我的方法是不断xor lowbit,这样的效率要比一位一位扫快一丢丢(虽然并快不了多少)。。
代码就是下面的query,自己看下就行了。。
好吧,然后下面直接上代码即可,这真的是一道非常水的线段树。。
#include <cstdio>
const int MAXN=400101;
int t[MAXN],lz[MAXN];
inline void swap(int &a,int &b)
{
int c=a;a=b;b=c;
}
inline int getnum()
{
int a=0;char c=getchar();bool f=0;
for(;(c<'0'||c>'9')&&c!='-'&&c!='C'&&c!='P';c=getchar());
if(c=='C') return -1;
if(c=='P') return -2;
if(c=='-') c=getchar(),f=1;
for(;c>='0'&&c<='9';c=getchar()) a=(a<<1)+(a<<3)+c-'0';
if(f) return -a; return a;
}
inline void update(int x)
{
t[x]=t[x<<1]|t[x<<1|1];
}
inline void pushdown(int x)
{
if(!lz[x]) return;
t[x<<1]=lz[x<<1]=t[x<<1|1]=lz[x<<1|1]=lz[x];
lz[x]=0;
}
void build(int x,int l,int r)
{
if(l==r)
{
t[x]=2;
return;
}
int mid=(l+r)>>1;
build(x<<1,l,mid);
build(x<<1|1,mid+1,r);
update(x);
}
void change(int x,int l,int r,int L,int R,int w)
{
if(L<=l&&r<=R)
{
t[x]=1<<w;
lz[x]=1<<w;
return;
}
pushdown(x);
int mid=(l+r)>>1;
if(L<=mid) change(x<<1,l,mid,L,R,w);
if(R>mid) change(x<<1|1,mid+1,r,L,R,w);
update(x);
}
int findans(int x,int l,int r,int L,int R)
{
int ans=0;
if(L<=l&&r<=R) return t[x];
pushdown(x);
int mid=(l+r)>>1;
if(L<=mid) ans|=findans(x<<1,l,mid,L,R);
if(R>mid) ans|=findans(x<<1|1,mid+1,r,L,R);
return ans;
}
int query(int ans)
{
int cnt=0;
for(;ans;ans^=(ans&-ans)) cnt++;
return cnt;
}
int main()
{
int n=getnum(),t=getnum(),m=getnum();
build(1,1,n);
while(m--)
{
int opt=getnum();
if(opt==-1)
{
int a=getnum(),b=getnum(),c=getnum();
if(a>b) swap(a,b);
change(1,1,n,a,b,c);
}
else
{
int a=getnum(),b=getnum();
if(a>b) swap(a,b);
printf("%d\n",query(findans(1,1,n,a,b)));
}
}
}
【学术篇】luogu1558&&poj2777 色板游戏的更多相关文章
- luogu 1558 色板游戏
写这篇博客不是为了总结我的算法,而是为了纪念让我爆零的套路..... 色板游戏 色板长度为\(L\),\(L\)是一个正整数,所以我们可以均匀地将它划分成\(L\)块\(1\)厘米长的小方格.并从左到 ...
- P1558 色板游戏
P1558 色板游戏 题目背景 阿宝上学了,今天老师拿来了一块很长的涂色板. 题目描述 色板长度为L,L是一个正整数,所以我们可以均匀地将它划分成L块1厘米长的小方格.并从左到右标记为1, 2, .. ...
- 洛谷P1558 色板游戏 [线段树]
题目传送门 色板游戏 题目背景 阿宝上学了,今天老师拿来了一块很长的涂色板. 题目描述 色板长度为L,L是一个正整数,所以我们可以均匀地将它划分成L块1厘米长的小方格.并从左到右标记为1, 2, .. ...
- AC日记——色板游戏 洛谷 P1558
色板游戏 思路: sb题: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 100005 struct Tre ...
- P1558 色板游戏 状压线段树
P1558 色板游戏 状压线段树 题面 洛谷P1558 每次不同颜色覆盖一段区间,每次询问一段区间有多少种颜色 因为颜色数\(T\)很小,使用二进制表示状态当前区间有那些颜色,二进制第\(i\)位表示 ...
- 【学术篇】一些水的不行的dp
最近做了几道非常水非常水的dp...... 之后刷的一些水dp也会写在这里...... 此篇题目难度不递增!!! Emmmm....... 1.luogu1043数字游戏 以前看过这个题几遍,没做这个 ...
- 《Genesis-3D开源游戏引擎完整实例教程-跑酷游戏篇03:暂停游戏》
3.暂停游戏 暂停游戏概述: 在游戏进行时,玩家有可能会遇到多种突发事件.在跑酷游戏中突发状况的发生对游戏的影响更甚,游戏进行时玩家死亡,游戏只能从头开始,那么如果因为外界因素而影响游戏的进行,显然是 ...
- 【pygame游戏编程】第四篇-----打字测速游戏
下面我们一起用pygame编写一个打字测速游戏 这是一个很实用的有趣的小游戏: 开始之前先来学习几个小函数: 1. ord(ch) python内置函数,传入一个字符,返回字符的ascii码 2.ch ...
- Luogu P1558 色板游戏
(此题与POJ2777重题) 为了加深对线段树的记忆,然后开始搞这道题. TM的WA了一下午就是发现x可能大于y(然而题目里说的还很清楚,我TM没看见) 这道题只需要在线段树的板子上改一些地方就可以了 ...
随机推荐
- npm run 同时执行多个命令
在项目中可能需要一套代码同时部署几套环境,每一次改动就需要同时打包N次.这时就需要能够一个命令同时打包多次,省去了很多麻烦. 这里我们需要用到 concurrently 这个 npm 包,能够实现我们 ...
- Linux命令(2):cat
cat命令是一个文本连接和查看的命令,用于文件的输出显示. 三大功能 一次显示整个文件. $ cat filename 从键盘创建一个文件.只能创建新文件,不能编辑已有文件. $ cat > f ...
- class13and14and15_登录窗口
最终的运行效果图(程序见序号6.2): #!/usr/bin/env python# -*- coding:utf-8 -*-# ----------------------------------- ...
- C/S通信
一直在考虑写一个服务端和客户端通信的框架,就现在的需求,打算走http协议. 通信方式打算用Key/Value的形式. 这里面其实还是有很多的问题的,这样的一个通信框架其实是SOA的一部分.其他 但是 ...
- DLL相关下断点
加载DLL 的时候断: sxe ld:[dll] 卸载DLL 的时候断: sxe ud:[dll] 比如: sxe ld:wininet.dll (在wininet.dll 被装载的时候断点) 这里 ...
- PE头里的东西更多。。。越看越恶心了,我都不想看了
winnt.h 中,定义的PE头结构体 typedef struct _IMAGE_NT_HEADERS{DWORD Signature;//PE文件头标志:PE\0\0.在开始DOS header的 ...
- Activiti学习笔记9 — UserTask共有任务的使用
1.创建流程引擎对象 private ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine(); 2.发布一个流程 ...
- @Formula
@Formula 计算临时属性. 相当于可以关联查询字段,然后放在实体中当做属性使用. 任务:在User实体层,增加一个额外的属性,来获取Test表中的name字段. 1 表结构 User表 Tes ...
- --master-data 的作用
Use this option to dump a master replication server to produce a dump file that can be used to set u ...
- Python|读、写Excel文件(三种模块三种方式)
python读写excel的方式有很多,不同的模块在读写的讲法上稍有区别: 用xlrd和xlwt进行excel读写: 用openpyxl进行excel读写: 用pandas进行excel读写: imp ...