loj #2037. 「SHOI2015」脑洞治疗仪
#2037. 「SHOI2015」脑洞治疗仪
题目描述
曾经发明了自动刷题机的发明家 SHTSC 又公开了他的新发明:脑洞治疗仪——一种可以治疗他因为发明而日益增大的脑洞的神秘装置。
为了简单起见,我们将大脑视作一个 01 序列。111 代表这个位置的脑组织正常工作,000 代表这是一块脑洞。
1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
脑洞治疗仪修补某一块脑洞的基本工作原理就是将另一块连续区域挖出,将其中正常工作的脑组织填补在这块脑洞中。(所以脑洞治疗仪是脑洞的治疗仪?)
例如,用上面第 888 号位置到第 101010 号位置去修补第 111 号位置到第 444 号位置的脑洞,我们就会得到:
1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 |
如果再用第 111 号位置到第 444 号位置去修补第 888 号位置到第 101010 号位置:
0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
这是因为脑洞治疗仪会把多余出来的脑组织直接扔掉。
如果再用第 777 号位置到第 101010 号位置去填补第 111 号位置到第 666 号位置:
1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
这是因为如果新脑洞挖出来的脑组织不够多,脑洞治疗仪仅会尽量填补位置比较靠前的脑洞。
假定初始时 SHTSC 并没有脑洞,给出一些挖脑洞和脑洞治疗的操作序列,你需要即时回答 SHTSC 的问题:在大脑某个区间中最大的连续脑洞区域有多大。
输入格式
第一行两个整数 nnn、mmm,表示 SHTSC 的大脑可分为从 111 到 nnn 编号的 nnn 个连续区域,有 mmm 个操作。
以下 mmm 行每行是下列三种格式之一:
- 0lr0\quad l\quad r0lr:SHTSC 挖了一个范围为 [l,r][l, r][l,r] 的脑洞。
- 1l0r0l1r11\quad l_0\quad r_0\quad l_1\quad r_11l0r0l1r1:SHTSC 进行了一次脑洞治疗,用从 l0l_0l0 到 r0r_0r0 的脑组织修补 l1l_1l1 到 r1r_1r1 的脑洞。
- 2lr2\quad l\quad r2lr:SHTSC 询问 [l,r][l, r][l,r] 区间内最大的脑洞有多大。
上述区间均在 [1,n][1, n][1,n] 范围内。
输出格式
对于每个询问,输出一行一个整数,表示询问区间内最大连续脑洞区域有多大。
样例
样例输入
10 10
0 2 2
0 4 6
0 10 10
2 1 10
1 8 10 1 4
2 1 10
1 1 4 8 10
2 1 10
1 7 10 1 6
2 1 10
样例输出
3
3
6
6
数据范围与提示
对于 20%20\%20% 的数据,n,m≤100n, m \leq 100n,m≤100;
对于 50%50\%50% 的数据,n,m≤20000n, m \leq 20000n,m≤20000;
对于 100%100\%100% 的数据,n,m≤200000n, m \leq 200000n,m≤200000。
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 200010
using namespace std;
int n,m,a[maxn];
int main(){
freopen("Cola.txt","r",stdin);
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)a[i]=;
int l,r,l1,r1,l2,r2,op;
while(m--){
scanf("%d",&op);
if(op==){
scanf("%d%d",&l,&r);
for(int i=l;i<=r;i++)a[i]=;
}
else if(op==){
scanf("%d%d%d%d",&l1,&r1,&l2,&r2);
int cnt=;
for(int i=l1;i<=r1;i++){
cnt+=a[i];
a[i]=;
}
for(int i=l2;i<=r2;i++){
if(cnt==)break;
if(a[i]==)a[i]=,cnt--;
}
}
else {
scanf("%d%d",&l,&r);
int ans=,cnt=;
for(int i=l;i<=r;i++){
if(a[i]==)cnt++;
else cnt=;
ans=max(ans,cnt);
}
printf("%d\n",ans);
}
}
return ;
}
50分 暴力
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 200010
using namespace std;
struct node{int l,r,sum,ans,sz;}tr[*maxn];
int tag[maxn*];
void tagit(int k,int d){
if(d==){
tr[k].l=tr[k].r=tr[k].ans=tr[k].sz;
tr[k].sum=;
}
else {
tr[k].l=tr[k].r=tr[k].ans=;
tr[k].sum=tr[k].sz;
}
tag[k]=d;
}
node update(node l,node r) {
node ans;
ans.l=l.l+(l.sum==?r.l:);
ans.r=r.r+(r.sum==?l.r:);
ans.sz=l.sz+r.sz;
ans.sum=l.sum+r.sum;
ans.ans=max(l.r+r.l,max(l.ans,r.ans));
return ans;
}
void release(int k) {
if (tag[k]!=-) {
int d=tag[k];
tag[k]=-;
tagit(k<<,d);
tagit(k<<|,d);
}
}
void build(int k,int l,int r){
tr[k].l=tr[k].r=tr[k].ans=;
tr[k].sz=tr[k].sum=r-l+;
tag[k]=-;
if(l==r)return;
int mid=(l+r)>>;
build(k<<,l,mid);build(k<<|,mid+,r);
}
void modify_0(int k,int l,int r,int opl,int opr){
if(l>=opl&&r<=opr){
tagit(k,);
return;
}
release(k);
int mid=(l+r)>>;
if(opl<=mid)modify_0(k<<,l,mid,opl,opr);
if(opr>mid)modify_0(k<<|,mid+,r,opl,opr);
tr[k]=update(tr[k<<],tr[k<<|]);
}
int modify_1(int k,int l,int r,int opl,int opr,int i){
if(l>=opl&&r<=opr){
int t=tr[k].sz-tr[k].sum;
if(t<=i){
tagit(k,);
return t;
}
release(k);
int mid=(l+r)>>;
int p=modify_1(k<<,l,mid,opl,opr,i);
if(p<i)p+=modify_1(k<<|,mid+,r,opl,opr,i-p);
tr[k]=update(tr[k<<],tr[k<<|]);
return p;
}
release(k);
int mid=(l+r)>>,t=;
if(opr<=mid)t=modify_1(k<<,l,mid,opl,opr,i);
else if(opl>mid)t=modify_1(k<<|,mid+,r,opl,opr,i);
else {
t=modify_1(k<<,l,mid,opl,opr,i);
if(t<i)t+=modify_1(k<<|,mid+,r,opl,opr,i-t);
}
tr[k]=update(tr[k<<],tr[k<<|]);
return t;
}
node query(int k,int l,int r,int opl,int opr){
if(l>=opl&&r<=opr)return tr[k];
release(k);
int mid=(l+r)>>;
if(opr<=mid)return query(k<<,l,mid,opl,opr);
else if(opl>mid)return query(k<<|,mid+,r,opl,opr);
else return update(query(k<<,l,mid,opl,opr),query(k<<|,mid+,r,opl,opr));
}
int main(){
freopen("Cola.txt","r",stdin);
int n,m;
scanf("%d%d",&n,&m);
build(,,n);
while(m--){
int op;scanf("%d",&op);
if(op==){
int l,r;
scanf("%d%d",&l,&r);
modify_0(,,n,l,r);
}
else if(op==){
int l0,r0,l1,r1;
scanf("%d%d%d%d",&l0,&r0,&l1,&r1);
node x=query(,,n,l0,r0);
modify_0(,,n,l0,r0);
if(x.sum)modify_1(,,n,l1,r1,x.sum);
}
else {
int l,r;
scanf("%d%d",&l,&r);
node x=query(,,n,l,r);
printf("%d\n",x.ans);
}
}
return ;
}
100分 线段树
loj #2037. 「SHOI2015」脑洞治疗仪的更多相关文章
- 【LOJ】#2037. 「SHOI2015」脑洞治疗仪
题解 维护区间内1的个数,左边数0的长度,右边数0的长度,区间内0区间最长个数,覆盖标记 第一种操作区间覆盖0 第二种操作查询\([l_0,r_0]\)中1的个数,区间覆盖0,然后覆盖时找到相对应的区 ...
- LibreOJ #2037. 「SHOI2015」脑洞治疗仪
线段树区间合并问题 恶心... 屠龙宝刀点击就送 #include <cstdio> #define N 200005 struct Segment { int l,r,mid,sum,l ...
- loj#2038. 「SHOI2015」超能粒子炮・改
题目链接 loj#2038. 「SHOI2015」超能粒子炮・改 题解 卢卡斯定理 之后对于%p分类 剩下的是个子问题递归 n,k小于p的S可以预处理,C可以卢卡斯算 代码 #include<c ...
- [LOJ 2039] 「SHOI2015」激光发生器
[LOJ 2039] 「SHOI2015」激光发生器 链接 链接 题解 分为两个部分 第一个是求直线之间的交点找到第一个触碰到的镜面 第二个是求直线经过镜面反射之后的出射光线 第一个很好做,第二个就是 ...
- Loj #2036. 「SHOI2015」自动刷题机
link : https://loj.ac/problem/2036 这个显然具有单调性,N小的话更容易A题,不仅因为A一次题减少的代码,并且A题的下限也低. 所以直接上二分就行了,注意上限一定不要设 ...
- LOJ#2039. 「SHOI2015」激光发生器(计算几何)
题面 传送门 题解 如果我初中科学老师知道我有一天计算的时候入射角不等于反射角不知道会不会把我抓起来打一顿-- 这题本质上就是个模拟,需要的芝士也就计蒜几盒的那点,不过注意细节很多,放到考场上只能看看 ...
- Loj #2192. 「SHOI2014」概率充电器
Loj #2192. 「SHOI2014」概率充电器 题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器: 「采用全新纳米级加工技术,实现元件与导线能否通电完 ...
- Loj #3096. 「SNOI2019」数论
Loj #3096. 「SNOI2019」数论 题目描述 给出正整数 \(P, Q, T\),大小为 \(n\) 的整数集 \(A\) 和大小为 \(m\) 的整数集 \(B\),请你求出: \[ \ ...
- Loj #3093. 「BJOI2019」光线
Loj #3093. 「BJOI2019」光线 题目描述 当一束光打到一层玻璃上时,有一定比例的光会穿过这层玻璃,一定比例的光会被反射回去,剩下的光被玻璃吸收. 设对于任意 \(x\),有 \(x\t ...
随机推荐
- 分布式锁之一:zookeeper分布式锁1
zookeeper集群的每个节点的数据都是一致的, 那么我们可以通过这些节点来作为锁的标志. 首先给锁设置一下API, 至少要包含, lock(锁住), unlock(解锁), isLocked(是否 ...
- MySQL 双主+keepalived 详细文档 M-M+keepalived
1. 操作系统,系统环境,目结结构,用户,权限,日志路径,脚本2. 配置规范化 1.1 操作系统准备 操作系统 Kylin Linux release 3.3.1707 (Core)数据库版本 mys ...
- Scala的Json序列化
import java.util.TimeZone import com.fasterxml.jackson.databind.{DeserializationFeature, ObjectMappe ...
- Celery-4.1 用户指南:Testing with Celery (用 Celery测试)
任务与单元测试 在单元测试中测试任务行为的推荐方法是用mocking. Eager mode: task_always_eager 设置启用的 eager 模式不适用于单元测试. 当使用eager模式 ...
- 前端js上传文件后端C#接收文件
本文粗略的讲下前端文件上传和后端文件接收的原理 前端代码 html <form onsubmit="uploadFile(event)"> <input type ...
- Rozor视图(c#代码与html混合编程原则)
(1)大括号的匹配原则(就近原则){} (2)html标签有截断c#代码的功能 @*服务器端的注释*@ <!--客户端注释-->
- NodeJS之Url的使用
一.通过http模块中的request事件可以得到在服务端拿到客户端的有关url的数据(req.url),其中req.url得到的数据是端口号后的所有路径,之后通过调入url模块对获取到的req.ur ...
- Howto Reboot or halt Linux system in emergency (ZT)
http://www.cyberciti.biz/tips/reboot-or-halt-linux-system-in-emergency.html Linux kernel includes ma ...
- Linux基础命令-文件与目录
Linux基础命令-文件与目录 参考:<鸟哥linux私房菜>五-七章,17/12/5复习,18/01/15复习 文件权限 rwx421:用户,用户组,其他 umask查看默认权限:000 ...
- solr search基础知识(控制符及其参数)
1.^ 控制符 (1)查询串上用^ 搜索: 天后王菲,如果希望将王菲的相关度加大,用^控制符. 天后 王菲^10.5 结果就会将含有王菲的document权重加大分数提高,排序靠前,10.5为权重 ...