HdU 4046 Panda 段树
链接:http://acm.hdu.edu.cn/showproblem.php?pid=4046
意甲冠军:到了bw组成的长度为n的字符串(n<=50000)。有m次操作(m<=10000),每次操作是询问一段范围内wbw的个数。或者改变一个字符成为w或b。
思路:建一棵线段树,每一个结点记录的是从L到R以每一个i为最左边的字母的总共的wbw的个数,单点更新的时候要更新三个点。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <map>
#include <cstdlib>
#include <queue>
#include <stack>
#include <vector>
#include <ctype.h>
#include <algorithm>
#include <string>
#include <set>
#include <ctime>
#define PI acos(-1.0)
#define INF 0x7fffffff
#define eps 1e-8
#define maxn 50005
typedef long long LL;
typedef unsigned long long ULL;
using namespace std;
int n,m,l,r;
int num[maxn*4];
char ss[maxn*4];
struct line
{
int left,right;
int n;
char value;
} a [maxn*4];
void build_tree(int l,int r,int step)
{
a[step].left=l;
a[step].right=r;
a[step].n=0;
if(l==r)
{
a[step].n=((l+2<=n)&&(ss[l]=='w'&&ss[l+1]=='b'&&ss[l+2]=='w'));
num[l]=step;
return;
}
int mid=(l+r)>>1;
build_tree(l,mid,step<<1);
build_tree(mid+1,r,step<<1|1);
a[step].n=a[step<<1].n+a[step<<1|1].n;
}
int ans;
void change(int s,int step,char k)
{
if(s==a[step].left&&s==a[step].right)
{
a[step].value=k;
ss[s]=k;
a[step].n=((l+2<=n)&&ss[s]=='w'&&ss[s+1]=='b'&&ss[s+2]=='w');
return;
}
if(a[step].left==a[step].right) return;
int mid=(a[step].left+a[step].right)>>1;
if(mid>=s) change(s,step<<1,k);
else change(s,step<<1|1,k);
a[step].n=a[step<<1].n+a[step<<1|1].n;
}
void change2(int s,int step)
{
if(s==a[step].left&&s==a[step].right)
{
a[step].n=(ss[s]=='w'&&ss[s+1]=='b'&&ss[s+2]=='w');
return;
}
if(a[step].left==a[step].right) return;
int mid=(a[step].left+a[step].right)>>1;
if(mid>=s) change2(s,step<<1);
else change2(s,step<<1|1);
a[step].n=a[step<<1].n+a[step<<1|1].n;
}
int query(int s,int t,int step)
{
if(a[step].left>=s&&a[step].right<=t)
{
ans+=a[step].n;
return 0;
}
else
{
int mid=(a[step].left+a[step].right)/2;
if(mid>=t) query(s,t,step<<1);
else if(mid<s) query(s,t,step<<1|1);
else
{
query(s,t,step<<1);
query(s,t,step<<1|1);
}
}
}
int main()
{
int T,q,L,R,p;
char k[2];
scanf("%d",&T);
for(int ii=1;ii<=T;ii++)
{
scanf("%d%d",&n,&m);
scanf("%s",ss+1);
printf("Case %d:\n",ii);
build_tree(1,n,1);
for(int i=0;i<m;i++)
{
scanf("%d",&q);
if(q==0)
{
ans=0;
scanf("%d%d",&L,&R);
if(R-1<L+1)
{
printf("0\n");
continue;
}
query(L+1,R-1,1);
printf("%d\n",ans);
}
else
{
scanf("%d%s",&p,&k);
change(p+1,1,k[0]);
if(p>=1)
change2(p,1);
if(p>=2)
change2(p-1,1);
}
}
}
return 0;
}
版权声明:本文博客原创文章。博客,未经同意,不得转载。
HdU 4046 Panda 段树的更多相关文章
- hdu 4046 Panda [线段树]
Panda Time Limit: 10000/4000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU 4046 Panda(树状数组)
Panda Time Limit: 10000/4000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- HDU 4046 Panda (ACM ICPC 2011北京赛区网络赛)
HDU 4046 Panda (ACM ICPC 2011北京赛区网络赛) Panda Time Limit: 10000/4000 MS (Java/Others) Memory Limit: ...
- hdu 4046 Panda 树状数组
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4046 When I wrote down this letter, you may have been ...
- HDU—4046 Panda (线段树)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=4046 题意:给出一个字符串,统计这个字符串任意区间中"wbw"出现的次数. 规定两 ...
- HDU 4046 Panda
线段树单点更新,要注意两段合并多出的答案的计算即可 //======================================================================== ...
- HDU 1542.Atlantis-线段树求矩形面积并(离散化、扫描线/线段树)-贴模板
好久没写过博客了,这学期不是很有热情去写博客,写过的题也懒得写题解.现在来水一水博客,写一下若干年前的题目的题解. Atlantis Time Limit: 2000/1000 MS (Java/Ot ...
- hdu 1542 Atlantis(段树&扫描线&面积和)
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- HDU 4125 Moles 段树+KMP
意甲冠军: 特定n, 下面是一个1-n该装置. 下面的二进制字符串. 按给定的建立二叉树安排. 然后遍历树(根->左子树->根->右子树->根) 当遍历节点 如果右值为奇数入栈 ...
随机推荐
- 重操JS旧业第二弹:数据类型与类型转换
一 数据类型 1 js中的数据类型 1.1 数据类型列举 1)number类型 2)boolean类型 3)string类型 4)对象类型 5)函数类型 6)undefined类型 1.2 数据类型获 ...
- Spring Session - Spring Boot
The completed guide can be found in the boot sample application. Updating Dependencies Before you us ...
- sum(case when then)(男女生的个数)
判断类似一个班级的男生和女生的人数,用sum (cese when then ) select count(er.execute_result), sum(case er.execute_result ...
- Godiva_百度百科
Godiva_百度百科 北京 三里屯 北京市朝阳区三里屯路19号院10号楼一层S10-13单元及二层S10-22单元 100027 北京朝阳大悦城北京市朝阳区朝阳北路101号朝阳大悦城1号商业楼1F- ...
- for_each的各种情况下的使用详解
原创作者:http://oomusou.cnblogs.com 配合<C++ Template>(简体中文)使用 http://download.csdn.net/detail/qq239 ...
- c# 使用OracleParameter,同时使用replace函数
也算不上是手误吧,这个问题竟然困扰了我那么多天,就是更新代码的时候,使用replace,但是oracle在.net下竟然是不支持汉字,所谓使用类似update x set y='m' where y= ...
- struts2官方演示程序总结struts2-blank
struts-2.2.3.1-all\struts-2.2.3.1\apps\struts2-blank总结 1.Html可以访问action ,如下: < head > ...
- Android:自定义滚动边缘(EdgeEffect)效果
Android可滚动控件(GridView.ListView.ScrollView等)当用户滚动到头的时候会有个边缘反馈效果,在4.0上默认为Holo蓝色效果. 如果您的App自定义了主题颜色,比如 ...
- VC 实现视图区背景颜色渐变填充
void CSTest1View::OnDraw(CDC* pDC) { CSTest1Doc* pDoc = GetDocument(); ASSERT_VALID(pDoc); // TODO: ...
- chfn,chsh,last,login,mail ,mesg ,talk,wall,write,nice ,pstree ,renice,skill ,expr ,reset,tset,compress ,lpd ,lpq ,lpr ,lprm,fdformat ,mformat ,mkdosf
名称:chfn 使用权限:所有使用者 用法:shell>> chfn 说明:提供使用者更改个人资讯,用于finger and mail username 范例: shell>> ...