Replacement
话说很久很久以前,孙悟空被压在了山下,很无聊。于是他找了一个只包含小写字母和字符"." 的字符串。 由于他比较无聊,他就开始了换点点,他找到字符串中第一个出现的"..",然后把其换成"."。 如果字符串中不包含"..",换点点操作对字符串无效
现在定义一个值f(s),表示使字符串不包含".."的最小 换点点 操作次数。
你现在需要处理m个询问, 第i个询问时,你需要把字符串中的 x (1 ≤ x ≤ n) 位置的字符替换成 c。替换后,输出 f(s)的值。
这下孙悟空一脸懵逼,快来帮帮他~
Input
第一行包括两个整数 n 和 m (1 ≤ n, m ≤ 300 000) ,分别表示字符串长度和询问次数。
第二行包含一个长度为n的字符串,字符串只包含小写字母和字符"."
接下来m行描述询问。第i行包括 x 和 c (1 ≤ x ≤ n, c — 一个小写字母或一个字符".")
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
*/