链接: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 段树的更多相关文章

  1. hdu 4046 Panda [线段树]

    Panda Time Limit: 10000/4000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  2. HDU 4046 Panda(树状数组)

    Panda Time Limit: 10000/4000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  3. HDU 4046 Panda (ACM ICPC 2011北京赛区网络赛)

    HDU 4046 Panda (ACM ICPC 2011北京赛区网络赛) Panda Time Limit: 10000/4000 MS (Java/Others)    Memory Limit: ...

  4. hdu 4046 Panda 树状数组

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4046 When I wrote down this letter, you may have been ...

  5. HDU—4046 Panda (线段树)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=4046   题意:给出一个字符串,统计这个字符串任意区间中"wbw"出现的次数. 规定两 ...

  6. HDU 4046 Panda

    线段树单点更新,要注意两段合并多出的答案的计算即可 //======================================================================== ...

  7. HDU 1542.Atlantis-线段树求矩形面积并(离散化、扫描线/线段树)-贴模板

    好久没写过博客了,这学期不是很有热情去写博客,写过的题也懒得写题解.现在来水一水博客,写一下若干年前的题目的题解. Atlantis Time Limit: 2000/1000 MS (Java/Ot ...

  8. hdu 1542 Atlantis(段树&amp;扫描线&amp;面积和)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  9. HDU 4125 Moles 段树+KMP

    意甲冠军: 特定n, 下面是一个1-n该装置. 下面的二进制字符串. 按给定的建立二叉树安排. 然后遍历树(根->左子树->根->右子树->根) 当遍历节点 如果右值为奇数入栈 ...

随机推荐

  1. CSS中的!important属性用法

    关于CSS的运用技巧有很多, 今天主要探讨一下CSS中 !important 这个属性的用法.在CSS的使用中,遇到最多的问题就是不同浏览器之间的兼容问题. 由于IE并不严格执行W3C标准, 而又几乎 ...

  2. 核心游记之 page_address_init

    lock_kernel()仅仅虚晃一枪就过去了. 紧接着来的是page_address_init include/linux/mm.h   #if defined(CONFIG_HIGHMEM) &a ...

  3. JS - 跳转页面

    <!-- 第一种: --> <script type="text/javascript"> window.location.href = "log ...

  4. shakes hands

    Description On February, 30th n students came in the Center for Training Olympiad Programmers (CTOP) ...

  5. 使用SetLocaleInfo设置时间后必须调用广播WM_SETTINGCHANGE,通知其他程序格式已经更改

    uses messages; Procedure SetDateFormat; //设置系统日期格式var buf:pchar; i:integer; p:DWORD;begin getmem(buf ...

  6. 一些关于linux 下的jni下问题

    编译的细节我就不写了,主要写一些linux下的注意事项,mask一下错误(太多windows的例子了) 编译教程:http://www.cnblogs.com/youxilua/archive/201 ...

  7. [页面模板框架对比] Apache Tiles VS Sitemesh

    1. 原理对比 (1) Apache Tiles 顾名思义,Tile是瓷砖的意思,也就是说一个网页是由多个Tile组成的. 用户通过访问一个页面的Apache Tiles定义名,就可以访问一个由定义文 ...

  8. io端口

    io端口 ***********************************************************   io端口设备访问流程为 --------------------- ...

  9. [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)

    ---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...

  10. ps中图层混合模式算法公式

    网上已经有很多讲解ps的图层混合模式,有些不详细甚至是错误的,参考网上给出的公式及其自己在验证推倒的,给出27种的混合模式算法公式.也许存在一定的错误性,毕竟没有官方给出公式,只能说以供参考吧. 只考 ...