During the War of Resistance Against Japan, tunnel warfare was carried out extensively in the vast areas of north China Plain. Generally speaking, villages connected by tunnels lay in a line. Except the two at the ends, every village was directly connected with two neighboring ones.

Frequently the invaders launched attack on some of the villages and destroyed the parts of tunnels in them. The Eighth Route Army commanders requested the latest connection state of the tunnels and villages. If some villages are severely isolated, restoration of connection must be done immediately!

Input

The first line of the input contains two positive integers n and m (n, m ≤ 50,000) indicating the number of villages and events. Each of the next m lines describes an event.

There are three different events described in different format shown below:

D x: The x-th village was destroyed.

Q x: The Army commands requested the number of villages that x-th village was directly or indirectly connected with including itself.

R: The village destroyed last was rebuilt.

Output

Output the answer to each of the Army commanders’ request in order on a separate line.

Sample Input

7 9

D 3

D 6

D 5

Q 4

Q 5

R

Q 4

R

Q 4

Sample Output

1

0

2

4

思路:

类似这题:(可以一起做了,)

https://www.cnblogs.com/qieqiemin/p/11385427.html

线段树处理连续区间的经典问题。

我们定义一个节点被轰炸为0,没被轰炸为1.

线段树每一个区间维护以下信息:

1、从左端点开始的最长连续1的个数。

2、从右端点开始的最长连续1的个数。

3、整个区间的最长连续1的个数。

4、是否整个区间是否都为1。

具体的转移和pushup看代码即可。

细节见代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define chu(x) cout<<"["<<#x<<" "<<(x)<<"]"<<endl
using namespace std;
typedef long long ll;
ll gcd(ll a, ll b) {return b ? gcd(b, a % b) : a;}
ll lcm(ll a, ll b) {return a / gcd(a, b) * b;}
ll powmod(ll a, ll b, ll MOD) {ll ans = 1; while (b) {if (b % 2)ans = ans * a % MOD; a = a * a % MOD; b /= 2;} return ans;}
inline void getInt(int* p);
const int maxn = 50010;
const int inf = 0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/
struct node
{
int l,r;
int num;
int isall;
int lm,rm;
}segmeng_tree[maxn<<2];
int n;
int m;
void pushup(int rt)
{
if(segmeng_tree[rt<<1].isall)
{
segmeng_tree[rt].isall=segmeng_tree[rt<<1|1].isall;
segmeng_tree[rt].lm=segmeng_tree[rt<<1].lm+segmeng_tree[rt<<1|1].lm;
if(segmeng_tree[rt<<1|1].isall)
segmeng_tree[rt].rm=segmeng_tree[rt<<1|1].rm+segmeng_tree[rt<<1].rm;
else
segmeng_tree[rt].rm=segmeng_tree[rt<<1|1].rm;
segmeng_tree[rt].num=max(segmeng_tree[rt].lm,segmeng_tree[rt].rm);
segmeng_tree[rt].num=max(segmeng_tree[rt].num,segmeng_tree[rt<<1].rm+segmeng_tree[rt<<1|1].lm);
}else if(segmeng_tree[rt<<1|1].isall)
{
segmeng_tree[rt].isall=segmeng_tree[rt<<1].isall;
segmeng_tree[rt].rm=segmeng_tree[rt<<1|1].rm+segmeng_tree[rt<<1].rm;
if(segmeng_tree[rt<<1].isall)
segmeng_tree[rt].lm=segmeng_tree[rt<<1|1].lm+segmeng_tree[rt<<1].lm;
else
segmeng_tree[rt].lm=segmeng_tree[rt<<1].lm;
segmeng_tree[rt].num=max(segmeng_tree[rt].lm,segmeng_tree[rt].rm);
segmeng_tree[rt].num=max(segmeng_tree[rt].num,segmeng_tree[rt<<1].rm+segmeng_tree[rt<<1|1].lm);
}else
{
segmeng_tree[rt].isall=0;
segmeng_tree[rt].lm=segmeng_tree[rt<<1].lm;
segmeng_tree[rt].rm=segmeng_tree[rt<<1|1].rm;
segmeng_tree[rt].num=max(segmeng_tree[rt].lm,segmeng_tree[rt].rm);
segmeng_tree[rt].num=max(segmeng_tree[rt].num,segmeng_tree[rt<<1].rm+segmeng_tree[rt<<1|1].lm);
}
}
void build(int rt,int l,int r)
{
segmeng_tree[rt].l=l;
segmeng_tree[rt].r=r;
if(l==r)
{
segmeng_tree[rt].num=segmeng_tree[rt].lm=segmeng_tree[rt].rm=segmeng_tree[rt].isall=1;
return;
}
int mid=(l+r)>>1;
build(rt<<1,l,mid);
build(rt<<1|1,mid+1,r);
pushup(rt);
} void update(int rt,int x,int val)
{
if(segmeng_tree[rt].l==segmeng_tree[rt].r)
{
if(val)
{
segmeng_tree[rt].isall=1;
}else
{
segmeng_tree[rt].isall=0;
}
segmeng_tree[rt].lm=segmeng_tree[rt].rm=segmeng_tree[rt].num=val;
}else
{
int mid=(segmeng_tree[rt].l+segmeng_tree[rt].r)>>1;
if(x<=mid)
{
update(rt<<1,x,val);
}else
{
update(rt<<1|1,x,val);
}
pushup(rt);
}
}
int ask(int rt,int x)
{
if(segmeng_tree[rt].l==segmeng_tree[rt].r||segmeng_tree[rt].isall||segmeng_tree[rt].num==0)
{
return segmeng_tree[rt].num;
}
int mid=(segmeng_tree[rt].l+segmeng_tree[rt].r)>>1;
if(x<=mid)
{
if(segmeng_tree[rt<<1].r-segmeng_tree[rt<<1].rm+1<=x)
{
return ask(rt<<1,x)+ask(rt<<1|1,mid+1);
}else
{
return ask(rt<<1,x);
}
}else
{
if(segmeng_tree[rt<<1|1].l+segmeng_tree[rt<<1|1].lm-1>=x)
{
return ask(rt<<1|1,x)+ask(rt<<1,mid);
}else
{
return ask(rt<<1|1,x);
}
}
}
stack<int> st;
int main()
{
//freopen("D:\\code\\text\\input.txt","r",stdin);
//freopen("D:\\code\\text\\output.txt","w",stdout);
while(~scanf("%d %d",&n,&m))
{
build(1,1,n);
while(!st.empty())
{
st.pop();
}
char s[22];
while(m--)
{
scanf("%s",s);
int x;
if(s[0]=='D')
{
scanf("%d",&x);
update(1,x,0);
st.push(x);
}else if(s[0]=='Q')
{
scanf("%d",&x);
printf("%d\n",ask(1,x));
}else
{
if(st.size())
{
x=st.top();
st.pop();
update(1,x,1);
}
}
}
}
return 0;
} inline void getInt(int* p) {
char ch;
do {
ch = getchar();
} while (ch == ' ' || ch == '\n');
if (ch == '-') {
*p = -(getchar() - '0');
while ((ch = getchar()) >= '0' && ch <= '9') {
*p = *p * 10 - ch + '0';
}
}
else {
*p = ch - '0';
while ((ch = getchar()) >= '0' && ch <= '9') {
*p = *p * 10 + ch - '0';
}
}
}

Tunnel Warfare HDU - 1540 (线段树处理连续区间问题)的更多相关文章

  1. I - Tunnel Warfare HDU - 1540 线段树最大连续区间

    题意  :一段区间  操作1 切断点 操作2 恢复最近切断的一个点 操作3 单点查询该点所在最大连续区间 思路:  主要是push_up :  设区间x 为母区间  x<<1 ,x< ...

  2. POJ 2892 Tunnel Warfare || HDU 1540(树状数组+二分 || 线段树的单点更新+区间查询)

    点我看题目 题意 :N个村子连成一条线,相邻的村子都有直接的地道进行相连,不相连的都由地道间接相连,三个命令,D x,表示x村庄被摧毁,R  ,表示最后被摧毁的村庄已经重建了,Q x表示,与x直接或间 ...

  3. E - Tunnel Warfare HDU - 1540 F - Hotel G - 约会安排 HDU - 4553 区间合并

    E - Tunnel Warfare HDU - 1540 对这个题目的思考:首先我们已经意识到这个是一个线段树,要利用线段树来解决问题,但是怎么解决呢,这个摧毁和重建的操作都很简单,但是这个查询怎么 ...

  4. Tunnel Warfare HDU 1540 区间合并+最大最小值

    Tunnel Warfare HDU 1540 区间合并+最大最小值 题意 D x是破坏这个点,Q x是表示查询以x所在的最长的连续的点的个数,R是恢复上一次破坏的点. 题解思路 参考的大佬博客 这里 ...

  5. Tunnel Warfare HDU - 1540(线段树最长连续区间)

    题意: 一条线上的点,D x是破坏这个点,Q x是表示查询以x所在的最长的连续的点的个数,R是恢复上一次破坏的点.   解析: 线段树结点 设置一个  lq记录区间左端点开始的最大连续个数,  rq ...

  6. Tunnel Warfare(hdu1540 线段树)

    Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

  7. Tunnel Warfare(HDU1540+线段树+区间合并)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1540 题目: 题意:总共有n个村庄,有q次操作,每次操作分为摧毁一座村庄,修复一座村庄,和查询与询问的 ...

  8. HDU - 1540 线段树的合并

    这个题题意我大概解释一下,就是一开始一条直线,上面的点全是联通的,有三种操作 1.操作D把从左往右第x个村庄摧毁,然后断开两边的联通. 2.询问Q节点相联通的最长长度 3.把最后破坏的村庄重建. 这个 ...

  9. hdu 1540 线段树

    这题的意思是现在有一些村庄成一条直线排列,现在有三个操作,D:摧毁一个指定的村庄,Q:询问与指定村庄相连的村庄个数, 就是这个村庄向左和向右数村庄数量,遇到尽头或损坏的村庄为止,这个就是与这个村庄相连 ...

随机推荐

  1. 3-3 man手册介绍

    man手册介绍 内容表示的意义: 各部分功能说明: SECTION: name:命令的名称及功能描述: SYNOPSIS:命令使用格式摘要: DESCRIPTION:详细描述信息: OPTIONS:选 ...

  2. 3分钟Markdown快速入门与使用

    Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容具有一定的格式. 注意:图片为效果图 1 标题 #开头代表标题,几个#号代表几级,最高支持六级标题 ...

  3. 【CodeForces - 707B】Bakery(思维水题)

    Bakery Descriptions 玛莎想在从1到n的n个城市中开一家自己的面包店,在其中一个城市烘焙松饼. 为了在她的面包房烘焙松饼,玛莎需要从一些储存的地方建立面粉供应.只有k个仓库,位于不同 ...

  4. DP,数论————洛谷P4317 花神的数论题(求1~n二进制中1的个数和)

    玄学代码(是洛谷题解里的一位dalao小粉兔写的) //数位DP(二进制)计算出f[i]为恰好有i个的方案数. //答案为∏(i^f[i]),快速幂解决. #include<bits/stdc+ ...

  5. 《九阴真经:iOS黑客攻防秘籍》新书发布

    本书内容易于理解,可以让读者循序渐进.系统性地学习iOS安全技术.书中首先细致地介绍了越狱环境的开发与逆向相关工具,然后依次讲解了汇编基础.动态调试.静态分析.注入与hook.文件格式,最后为大家呈现 ...

  6. Centos7 安装python3.8和pip

    安装python3 yum -y install yum-utilsyum-builddep pythoncurl -O https://www.python.org/ftp/python/3.8.0 ...

  7. [转帖]calico网络原理及与flannel对比

    calico网络原理及与flannel对比 https://blog.csdn.net/ganpuzhong42/article/details/77853131 2017年09月05日 16:34: ...

  8. centOS重启网络服务报错

    1:启动网卡报错(Failed to start LSB: Bring up/down networking )解决办法总结 将 NetworkManager关闭, systemctl stop Ne ...

  9. Springboot问题解决记录

    本随笔只为了方便查阅 如何将SpringBoot项目地打成一个war包: 传送门:https://blog.csdn.net/zhoucheng05_13/article/details/779152 ...

  10. idea的配置文件------application.properties和application.yml

    当application.yml 和 application.properties 两个文件同时存在的时候,application.properties的优先级是高于application.yml的, ...