Replacement

CodeForces - 570C

话说很久很久以前,孙悟空被压在了山下,很无聊。于是他找了一个只包含小写字母和字符"." 的字符串。 由于他比较无聊,他就开始了换点点,他找到字符串中第一个出现的"..",然后把其换成"."。 如果字符串中不包含"..",换点点操作对字符串无效

现在定义一个值f(s),表示使字符串不包含".."的最小 换点点 操作次数。

你现在需要处理m个询问, 第i个询问时,你需要把字符串中的 xi (1 ≤ xi ≤ n) 位置的字符替换成 ci。替换后,输出 f(s)的值。

这下孙悟空一脸懵逼,快来帮帮他~

Input

第一行包括两个整数 n 和 m (1 ≤ n, m ≤ 300 000) ,分别表示字符串长度和询问次数。

第二行包含一个长度为n的字符串,字符串只包含小写字母和字符"."

接下来m行描述询问。第i行包括 xi 和 ci (1 ≤ xi ≤ nci — 一个小写字母或一个字符".")

Output

输出m个数字,每个一行 ,输出执行第i个替换后的f(s)值。

Example

Input
10 3
.b..bz....
1 h
3 c
9 f
Output
4
3
1
Input
4 4
.cc.
2 .
3 .
2 a
1 a
Output
1
3
1
1

Note

第一个样例

初始串:".b..bz....".

  • 第一次询问: f(hb..bz....) = 4    ("hb[..]bz...."  →  "hb.bz[..].."  → "hb.bz[..]."  →  "hb.bz[..]"  →  "hb.bz.")
  • 第二次询问: f(hbс.bz....) = 3    ("hbс.bz[..].."  →  "hbс.bz[..]."  → "hbс.bz[..]"  →  "hbс.bz.")
  • 第三次询问: f(hbс.bz..f.) = 1    ("hbс.bz[..]f."  →  "hbс.bz.f.")

第二个样例

初始串:".cc.".

  • 第一次询问: f(..c.) = 1    ("[..]c."  →  ".c.")
  • 第二次询问: f(....) = 3    ("[..].."  →  "[..]."  →  "[..]"  →  ".")
  • 第三次询问:f(.a..) = 1    (".a[..]"  →  ".a.")
  • 第四次询问:f(aa..) = 1    ("aa[..]"  →  "aa.")

sol:有加强版的是区间修改(我一眼秒了)--摘自某大佬原话

我太菜了,于是只会做弱化弱化弱化弱化版

首先很显然的东西,合并的次数= '.' 的个数和连续的 '.' 的段数。所以我们只要维护那两个东西

因为是单点修改,大力枚举四种情况即可

Ps:码力太弱,有些吃力

#include <bits/stdc++.h>
using namespace std;
typedef int ll;
inline ll read()
{
ll s=;
bool f=;
char ch=' ';
while(!isdigit(ch))
{
f|=(ch=='-'); ch=getchar();
}
while(isdigit(ch))
{
s=(s<<)+(s<<)+(ch^); ch=getchar();
}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<)
{
putchar('-'); x=-x;
}
if(x<)
{
putchar(x+''); return;
}
write(x/);
putchar((x%)+'');
return;
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
const int N=;
int n,m;
char S[N];
int main()
{
int i,j,cnt=,Duans=;
R(n); R(m);
scanf("%s",S+);
for(i=;i<=n;i++) if(S[i]=='.') cnt++;
for(i=;i<=n;i++) if(S[i]=='.')
{
for(j=i;j<=n&&(S[j]=='.');j++);
Duans++;
i=j;
}
while(m--)
{
int Pos=read();
char SS[],ch;
scanf("%s",SS+); ch=SS[];
if(((S[Pos]=='.')||(ch=='.'))&&(S[Pos]!=ch))
{
if(S[Pos]=='.')
{
cnt--;
if(Pos>&&S[Pos-]=='.'&&Pos<n&&S[Pos+]=='.') Duans++;
if((Pos==||S[Pos-]!='.')&&(Pos==n||S[Pos+]!='.')) Duans--;
}
else
{
cnt++;
if(Pos>&&S[Pos-]=='.'&&Pos<n&&S[Pos+]=='.') Duans--;
if((Pos==||S[Pos-]!='.')&&(Pos==n||S[Pos+]!='.')) Duans++;
}
}
S[Pos]=ch;
// printf("cnt=%d Duans=%d\n",cnt,Duans);
Wl(cnt-Duans);
}
return ;
}
/*
input
10 3
.b..bz....
1 h
3 c
9 f
output
4
3
1 input
4 4
.cc.
2 .
3 .
2 a
1 a
output
1
3
1
1
*/

codeforces570C的更多相关文章

  1. Codeforces570C 【简单标记】

    题意: 给定一个长为n的字符串(包含小写字母和'.'),有m次操作 每次操作可以修改字符,并询问修改后有多少对相邻的'.' 思路: 标记. #include<bits/stdc++.h> ...

随机推荐

  1. git pull 解决 refusing to merge unrelated histories 错误

    解决办法: 1.cmd进入项目的根目录. 2.执行下面的命令:git pull origin master --allow-unrelated-histories.可以提交成功. 3.再次push.

  2. FineUIPro v3.5.0发布了,减少 90% 的上行数据量,15行代码全搞定!

    一切为客户着想 一切的一切还得从和一位台湾客户的沟通说起: 客户提到将ViewState保存在服务器端以减少上行数据量,从而加快页面的回发速度. 但是在FineUI中,控件状态都保存在FState中, ...

  3. Git超实用总结,再也不怕记忆力不好了

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯工蜂发表于云+社区专栏 Git 是什么? Git 是一个分布式的代码管理容器,本地和远端都保有一份相同的代码. Git 仓库主要是 ...

  4. NetCore实践篇:分布式监控客户端ZipkinTracer从入门到放弃之路

    前言 本文紧接上篇.Net架构篇:思考如何设计一款实用的分布式监控系统?,上篇仅仅是个思考篇,跟本文没有太大的关系.但有思考,结合现有的开源组件,实践起来更易理解起来,所以看本文之前,应该先看下上篇博 ...

  5. c++入门之类与内存

    类作为c++编程的核心,自然我们十分关注其内存分配问题. 这里的这个主题中,我们关注了静态成员,new,delete.还有构造函数和析构函数. 先上代码: # include "iostre ...

  6. Yii框架的增删改查总结分析

    一.查询数据 1.findAll(根据一个条件查询一个集合) $admin=Admin::model()->findAll($condition,$params); $admin=Admin:: ...

  7. elasticsearch聚合操作——本质就是针对搜索后的结果使用桶bucket(允许嵌套)进行group by,统计下分组结果,包括min/max/avg

    分析 Elasticsearch有一个功能叫做聚合(aggregations),它允许你在数据上生成复杂的分析统计.它很像SQL中的GROUP BY但是功能更强大. 举个例子,让我们找到所有职员中最大 ...

  8. mac下的快捷键

    功能 快捷键 通用 打开新窗口 command + n 打开新标签 command + t 关闭标签 command + w 缩小 command - 放大 command + 全屏.取消全屏 com ...

  9. FAIL - Deploy Upload Failed, Exception: [org.apache.tomcat.util.http.fileupload.FileUploadBase$SizeLimitExceededException: the request was rejected because its size (112503036) exceeds the configured

    Message:  FAIL - Deploy Upload Failed, Exception: [org.apache.tomcat.util.http.fileupload.FileUpload ...

  10. vue传参

    <template> <ul> <li v-for="item in list" :key="item.id"> <b ...