操作无论是U还是L,都会使原图形分裂成两个图形,且两个图形的操作互不影响

我们又发现由于操作点只可能在下斜线上,如果将操作按x排序

那么无论是U还是L,都会将操作序列完整分割成两半,且两个操作序列互不影响

这样我们就可以对操作进行分治,每次找到最靠前的操作,并将操作序列分割

对于U操作而言,计算其答案只需要知道当前列最靠下的那一行

对于L操作而言,计算其答案只需要知道当前行最靠右的那一列

分治的时候动态维护即可

注:这样的话最坏情况会递归20w层,在CF上会爆栈,所以我的代码人为的开了栈空间

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cstdlib>
#include<map>
#include<iostream>
using namespace std; const int maxn=200010;
int n,m;
struct OP{
int a,b,id;
char c;
}A[maxn];
int mn[maxn<<2];
int ans[maxn];
map<int,bool>vis; bool cmp(const OP &A,const OP &B){return A.a<B.a;}
void ch_read(char &ch){
ch=getchar();
while(ch<'!')ch=getchar();
}
int Min(int a,int b){return A[a].id<A[b].id?a:b;}
void build(int o,int L,int R){
if(L==R){mn[o]=L;return;}
int mid=(L+R)>>1;
//cout<<mid<<endl;
build(o<<1,L,mid);
build(o<<1|1,mid+1,R);
mn[o]=Min(mn[o<<1],mn[o<<1|1]);
}
int ask(int o,int L,int R,int x,int y){
if(L>=x&&R<=y)return mn[o];
int mid=(L+R)>>1;
if(y<=mid)return ask(o<<1,L,mid,x,y);
else if(x>mid)return ask(o<<1|1,mid+1,R,x,y);
else return Min(ask(o<<1,L,mid,x,y),ask(o<<1|1,mid+1,R,x,y));
}
void Solve(int L,int R,int Low,int Right){
if(L>R)return;
int now=ask(1,1,m,L,R);
if(vis[A[now].a]){
Solve(L,now-1,Low,Right);
Solve(now+1,R,Low,Right);
return;
}
vis[A[now].a]=true;
if(A[now].c=='U'){
ans[A[now].id]=A[now].b-Low;
Solve(L,now-1,Low,Right);
Solve(now+1,R,Low,A[now].a);
}else{
ans[A[now].id]=A[now].a-Right;
Solve(L,now-1,A[now].b,Right);
Solve(now+1,R,Low,Right);
}return;
} int main(){
int __size__ = 20 << 20; // 20MB
char *__p__ = (char*)malloc(__size__) + __size__;
__asm__("movl %0, %%esp\n" :: "r"(__p__));
scanf("%d%d",&n,&m);
for(int i=1;i<=m;++i){
scanf("%d%d",&A[i].a,&A[i].b);
ch_read(A[i].c);A[i].id=i;
}
sort(A+1,A+m+1,cmp);
build(1,1,m);
Solve(1,m,0,0);
for(int i=1;i<=m;++i)printf("%d\n",ans[i]);
return 0;
}

  

另外附上官方题解:

还是上面的思路,我们很容易发现:

对于每一行,只需要知道其最靠右覆盖的列

对于每一列,只需要知道其最靠下覆盖的行

我们可以建两棵线段树,分别维护行的信息和列的信息

每次操作分别更改两棵线段树即可

又因为n很大,所以我们需要对行和列离散化

codeforces #310 div1 C的更多相关文章

  1. codeforces #310 div1 E

    算得上是比较水的E题了吧,自己想了想写了写居然1A了 对于这道题,我们很容易想到对于原图的一个边双,定向后任意两点间一定可达 那么我们可以求出原图的边双并将每个边双缩成一个点 那么原图就变成了无环的无 ...

  2. codeforces #310 div1 D

    一开始写了个暴力模拟绳子的摆动轨迹 然后在Test 16 T掉了 后来%了一下别人的代码,发现需要对特殊情况进行特殊处理 首先我们考虑绳子的向右摆动,设当前位置为p,绳子当前长度为L 如果其旋转中心位 ...

  3. codeforces #310 div1 B

    我们考虑n-1座桥每座桥需要的长度在一个区间[L,R]中 之后我们现在有m座桥,每个桥的长度为k 题意就是要求一个匹配方案 显然如果数据范围不大直接KM就可以了 可是20w的数据KM显然要T 所以我们 ...

  4. codeforces #310 div1 A

    首先我们考虑最暴力的拆解拼凑 显然拆分掉所有的链需要 n-m 次 之后拼凑需要 n-1 次 然后由题目规定可知:只有从1出发且连续的链不用拆掉,其余的都必须拆掉(因为两个都套有娃娃的套娃不能组合) 我 ...

  5. codeforces 407 div1 B题(Weird journey)

    codeforces 407 div1 B题(Weird journey) 传送门 题意: 给出一张图,n个点m条路径,一条好的路径定义为只有2条路径经过1次,m-2条路径经过2次,图中存在自环.问满 ...

  6. codeforces 407 div1 A题(Functions again)

    codeforces 407 div1 A题(Functions again) Something happened in Uzhlyandia again... There are riots on ...

  7. codeforces #313 div1 E

    首先我们要注意到一个事情 如果一个灯塔向左覆盖,那么比他小的某个灯塔如果向左覆盖的端点大于当前塔向左覆盖的端点,他一定向右覆盖 对于当前灯塔向右覆盖也是同理 那么我们只需要记录当前覆盖到的端点就可以完 ...

  8. codeforces #305 div1 done

    总算搞定了这一场比赛的题目,感觉收获蛮大 其中A,B,C都能通过自己的思考解决掉 D题思路好神,E题仔细想想也能想出来 以后坚持每两天或者一天做一场CF的div1的全套题目 除非有实在无法做出来的题目 ...

  9. Codeforces #254 div1 B. DZY Loves FFT 暴力乱搞

    B. DZY Loves FFT 题目连接: http://codeforces.com/contest/444/problem/B Description DZY loves Fast Fourie ...

随机推荐

  1. VxWorks 6.9 内核编程指导之读书笔记 -- VxWorks Small-Footprint Configuration

    什么是Small-footprint? Small-footprint常见关键配置? 如何配置Small-footprint? 什么是Small-footprint? Small-footprint配 ...

  2. 设置 MyEclipse 默认打开文件方式

         在web开发时,我们在打开JSP页面时,MyEclipse默认使用 Vistual 的方式打开.这种方式打开JSP页面时,很慢.在实际的开发过程中我们不想使用这种默认的方式打开JSP.设置如 ...

  3. javascript 笔记——bind 用法小技巧

    $(function(){ //代码阅读能力 function speak(name){ return "Hello " + name; } //此处写代码 //方法一 //重点是 ...

  4. will VS be going to

    1.Future - Will vs. Going to 2."Will be doing" vs. "will do" 3.Simple Future

  5. DEDECMS中,友情链接

    友情链接:dede:flink {dede:flink row='24' type='image' titlelen="24" typeid="0"} [fie ...

  6. 看几道JQuery试题后总结(上篇)

    无意中拿到的JQuery题目,拿来分享顺便总结总结 在JQuery对象中区分.text();.val();.html();.innerHTML;.innerTEXT()的用法与区别,用例子证明 在JQ ...

  7. Scrapy简介

    什么是Scrapy? Scrapy是一个快速.高级的爬行器和网页抓取框架,用来抓取网站和提取网页中结构化的数据.它被广泛的使用于监控数据采集和自动化测试. 参考:http://scrapy.org/

  8. Android中获取应用程序(包)的大小-----PackageManager的使用(二)

    通过第一部分<<Android中获取应用程序(包)的信息-----PackageManager的使用(一)>>的介绍,对PackageManager以及 AndroidMani ...

  9. Java字符串之性能优化

    基础类型转化成String 在程序中你可能时常会需要将别的类型转化成String,有时候可能是一些基础类型的值.在拼接字符串的时候,如果你有两个或者多个基础类型的值需要放到前面,你需要显式的将第一个值 ...

  10. 获取局域网ip

    显然不可使用基于request请求的request.getRemoteAddr()这个是获取广域网内的服务器地址,比如我请求百度使用这个方法就可以获取到百度的服务器地址 那么InetAddress的I ...