题目
给你一个只包含字符 ‘a’,‘b’ 和 ‘c’ 的字符串 s ,你可以执行下面这个操作(5 个步骤)任意次:
选择字符串 s 一个 非空 的前缀,这个前缀的所有字符都相同。
选择字符串 s 一个 非空 的后缀,这个后缀的所有字符都相同。
前缀和后缀在字符串中任意位置都不能有交集。
前缀和后缀包含的所有字符都要相同。
同时删除前缀和后缀。
请你返回对字符串 s 执行上面操作任意次以后(可能 0 次),能得到的 最短长度 。
思路
利用双指针来做,先进行do操作为了避免不相等时候的死循环
代码
class Solution {
public:
int minimumLength(string s) {
int l = 0, r = s.size() - 1;
while(l < r && s[l] == s[r]){
do l++; while(l < r && s[l] == s[l - 1]);
do r--; while(l < r && s[r] == s[r + 1]);
}
return r - l + 1;
}
};