Problem - 1555D - Codeforces
如果这个字符串不包含一个长度至少为2的子串,我们就称它为美丽的字符串,这是一个回文。回顾一下,回文是指从第一个字符到最后一个字符以及从最后一个字符到第一个字符的读法相同的字符串。例如,字符串a, bab, acca, bcabcbacb是回文,但字符串ab, abbbaa, cccb不是。
让我们把字符串的成本定义为:如果在一次操作中允许将字符串的任何一个字符改为拉丁字母表的前三个字母之一(小写),那么该字符串变得漂亮的最小操作数。
给你一个长度为n的字符串s,字符串的每个字符都是拉丁字母表的前3个字母之一(小写)。
你必须回答m个查询--计算从第li-th到ri-th位置的字符串s的子串的成本,包括在内。
输入
第一行包含两个整数n和m(1≤n,m≤2⋅105)--字符串s的长度和查询次数。
第二行包含字符串s,它由n个字符组成,每个字符是前3个拉丁字母之一。
接下来的m行包含两个整数li和ri(1≤li≤ri≤n)--第i个查询的参数。
输出
对于每个查询,打印一个整数--从li-th到ri-th位置的字符串s的子串的费用,包括在内。
例子
inputCopy
5 4
baacb
1 3
1 5
4 5
2 3
输出拷贝
1
2
0
1
注意
考虑一下测试示例中的查询。
在第一个查询中,子串是baa,可以通过一次操作改变为bac。
在第二个查询中,子串是baacb,可以通过两次操作改变为cbacb。
在第三个查询中,子串是cb,可以不做任何改变。
在第四个查询中,子串是aa,可以通过一次操作变为ba。
题解:
题中说不能出现长度大于等于2的回文串,且串只由三个字母abc组成
满足条件的串应该是abcabc这种形式的否则无论如何都无法成立
类似这种形式的有
abcabc
acbacb
bacbac
bcabca
cabcab
cbacba
所以我们用前缀和预处理出来s串由这6种方式构成,各需要多少代价
询问时找最小输出即可
#include<iostream>
#include<algorithm>
#include<string>
#include<queue>
#include<vector>
#include<map>
#include<cstring>
#include<cmath>
using namespace std;
#define int long long
char s[6][5] = {"abc","acb","bac","bca","cab","cba"};
int f[200050][6];
void solve()
{
int n,m;
cin >> n>> m;
string ss;
cin >> ss;
ss = " "+ ss;
for(int i = 1;i <= n;i++)
{
int k = (i-1)%3;
for(int j = 0;j < 6;j++)
{
f[i][j] = f[i-1][j] + (ss[i] != s[j][k]);
}
}
while(m--)
{
int l,r;
cin >> l >> r;
int mi = 1e9;
for(int i = 0;i < 6;i++)
{
mi = min(mi,f[r][i] - f[l-1][i]);
}
cout<<mi<<"\n";
}
}
//aaaa
//bacb
signed main()
{
// ios::sync_with_stdio(false);
// cin.tie(0);
// cout.tie(0);
int t = 1;
// cin >> t;
while(t--)
{
solve();
}
}
//10