AC日记——妖梦斩木棒 洛谷 P3797
思路:
略坑爹;
代码:
- #include <bits/stdc++.h>
- using namespace std;
- #define maxn 200005
- #define maxm maxn<<2
- int n,m,L[maxm],R[maxm],mid[maxm],dis[maxm];
- bool xx[maxm],ll[maxm],rr[maxm];
- struct AnsType {
- int dis;
- bool l,r,x;
- };
- inline void in(int &now)
- {
- char Cget=getchar();now=;
- while(Cget>''||Cget<'')Cget=getchar();
- while(Cget>=''&&Cget<='')
- {
- now=now*+Cget-'';
- Cget=getchar();
- }
- }
- void updata(int now)
- {
- xx[now]=xx[now<<]&xx[now<<|];
- dis[now]=dis[now<<]+dis[now<<|];
- if(rr[now<<]&&ll[now<<|]&&!xx[now<<]&&!xx[now<<|]) dis[now]++;
- ll[now]=xx[now<<]?ll[now<<|]:ll[now<<];
- rr[now]=xx[now<<|]?rr[now<<]:rr[now<<|];
- }
- struct AnsType node(AnsType a,AnsType b)
- {
- AnsType res;
- res.x=a.x&b.x;
- res.l=a.x?b.l:a.l;
- res.r=b.x?a.r:b.r;
- res.dis=a.dis+b.dis;
- if(a.r&&b.l&&!a.x&&!b.x) res.dis++;
- return res;
- }
- void build(int now,int l,int r)
- {
- L[now]=l,R[now]=r;
- if(l==r)
- {
- if(l==) rr[now]=;
- else if(r==n) ll[now]=;
- else xx[now]=,ll[now]=,rr[now]=;
- return;
- }
- mid[now]=l+r>>;
- build(now<<,l,mid[now]);
- build(now<<|,mid[now]+,r);
- updata(now);
- }
- void updata(int now,int to,int t)
- {
- if(L[now]==R[now])
- {
- ll[now]=rr[now]=xx[now]=;
- if(t==) xx[now]=,ll[now]=,rr[now]=;
- if(t==) ll[now]=;
- if(t==) rr[now]=;
- return ;
- }
- if(to<=mid[now]) updata(now<<,to,t);
- else updata(now<<|,to,t);
- updata(now);
- }
- AnsType query(int now,int l,int r)
- {
- if(L[now]==l&&R[now]==r) return (AnsType){dis[now],ll[now],rr[now],xx[now]};
- if(r<=mid[now]) return query(now<<,l,r);
- else if(l>mid[now]) return query(now<<|,l,r);
- else return node(query(now<<,l,mid[now]),query(now<<|,mid[now]+,r));
- }
- int main()
- {
- in(n),in(m),build(,,n);
- int op,l,r,x;char ch[];
- while(m--)
- {
- in(op);
- if(op==)
- {
- in(x),scanf("%s",ch);
- if(ch[]=='X') ch[]=;
- else if(ch[]==')') ch[]=;
- else ch[]=;
- updata(,x,ch[]);
- }
- else
- {
- in(l),in(r);
- AnsType res=query(,l,r);
- printf("%d\n",res.dis);
- }
- }
- return ;
- }
AC日记——妖梦斩木棒 洛谷 P3797的更多相关文章
- AC日记——妖梦拼木棒 洛谷 P3799
妖梦拼木棒 思路: 神特么题: 代码: #include <bits/stdc++.h> using namespace std; #define mod 1000000007LL int ...
- 洛谷 P3797 妖梦斩木棒 解题报告
P3797 妖梦斩木棒 妖梦是住在白玉楼的半人半灵,拥有使用剑术程度的能力. 题目描述 有一天,妖梦正在练习剑术.地面上摆放了一支非常长的木棒,妖梦把它们切成了等长的\(n\)段.现在这个木棒可以看做 ...
- 洛谷P3797 妖梦斩木棒
P3797 妖梦斩木棒 题目背景 妖梦是住在白玉楼的半人半灵,拥有使用剑术程度的能力. 题目描述 有一天,妖梦正在练习剑术.地面上摆放了一支非常长的木棒,妖梦把它们切成了等长的n段.现在这个木棒可以看 ...
- 洛谷 P3797 妖梦斩木棒
https://www.luogu.org/problem/show?pid=3797 题目背景 妖梦是住在白玉楼的半人半灵,拥有使用剑术程度的能力. 题目描述 有一天,妖梦正在练习剑术.地面上摆放了 ...
- [luogu P3797] 妖梦斩木棒 [线段树]
题目背景 妖梦是住在白玉楼的半人半灵,拥有使用剑术程度的能力. 题目描述 有一天,妖梦正在练习剑术.地面上摆放了一支非常长的木棒,妖梦把它们切成了等长的n段.现在这个木棒可以看做由三种小段构成,中间的 ...
- [Luogu3797] 妖梦斩木棒
题目背景 妖梦是住在白玉楼的半人半灵,拥有使用剑术程度的能力. 题目描述 有一天,妖梦正在练习剑术.地面上摆放了一支非常长的木棒,妖梦把它们切成了等长的n段.现在这个木棒可以看做由三种小段构成,中间的 ...
- Luogu P3797 妖梦斩木棒
解题思路 用线段树做这个就不用说了吧,但是要维护的东西确实很神奇.在每一个节点上都维护一个$lbkt$,表示这个区间上最靠左的右括号的位置:一个$rbkt$,表示这个区间上最靠右的左括号的位置.还有一 ...
- AC日记——校门外的树 洛谷 P1047
题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0,1,2,……,L,都种 ...
- AC日记——无线网络发射器选址 洛谷 P2038
题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...
随机推荐
- Codeforces Round #326 (Div. 2) B Duff in Love 简单数论 姿势涨
B. Duff in Love time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- HDU1828线段树(扫描线)
Picture Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- DataXceiver error processing unknown operation src: /127.0.0.1:36479 dst: /127.0.0.1:50010处理
异常信息如下: 2015-12-09 17:39:20,310 ERROR datanode.DataNode (DataXceiver.java:run(278)) - hadoop07:50010 ...
- Python to list users in AWS
code import boto3 c1=boto3.client('iam') #list_users will be a dict users=c1.list_users() #transfer ...
- CSS3 :empty 选择器
这可是个好东西,我也是这个星期才发现的,下面我们来说具体功能. <!DOCTYPE html> <html> <head> <meta charset=&qu ...
- HDU5852 Intersection is not allowed!
There are K pieces on the chessboard. The size of the chessboard is N*N. The pieces are initially pl ...
- 【BZOJ】1704: [Usaco2007 Mar]Face The Right Way 自动转身机
[题意]n头牛,一些向前一些向后,每次可以使连续k头牛转身,求使旋转次数最小的k. [算法]贪心 [题解]这题题解很迷,大概思想是k没有单调性,故枚举k,从左到右扫描遇到一只向后的牛就旋转一次. 贪心 ...
- ajax post请求json数据在spring-controller解析
1.前端post请求数据: userInfo=[{"id":"5","uname":"小李","phone&q ...
- 复现VGG19训练自定义图像分类
1.复现VGG训练自定义图像分类,成功了哈哈. 需要代码工程可联系博主qq号,在左边连接可找到. 核心代码: # coding:utf-8 import tensorflow as tf import ...
- Part2-HttpClient官方教程-Chapter1-基础
前言 超文本传输协议(HTTP)可能是当今Internet上使用的最重要的协议.Web服务.网络支持的设备和网络计算的增长继续扩展了HTTP协议在用户驱动的Web浏览器之外的作用,同时增加了需要HTT ...