给你一个字符串 s,「k 倍重复项删除操作」将会从 s 中选择 k 个相邻且相等的字母,并删除它们,使被删去的字符串的左侧和右侧连在一起。
你需要对 s 重复进行无限次这样的删除操作,直到无法继续为止。
在执行完所有删除操作后,返回最终得到的字符串。
本题答案保证唯一。
示例 1:
输入:s = "abcd", k = 2
输出:"abcd"
解释:没有要删除的内容。
示例 2:
输入:s = "deeedbbcccbdaa", k = 3
输出:"aa"
解释:
先删除 "eee" 和 "ccc",得到 "ddbbbdaa"
再删除 "bbb",得到 "dddaa"
最后删除 "ddd",得到 "aa"
示例 3:
输入:s = "pbbcggttciiippooaais", k = 2
输出:"ps"
提示:
1 <= s.length <= 10^5
2 <= k <= 10^4
s 中只含有小写英文字母。
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/remove-all-adjacent-duplicates-in-string-ii 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
public:
string removeDuplicates(string s, int k) {
int i, count = 0;
stack<pair<char,int>> stk;
char prev = '*';
for(i = 0; i < s.size(); ++i)
{
if(prev != s[i])
{
count = 1;
stk.push(make_pair(s[i],count));
prev = s[i];
}
else//prev == s[i]
{
count = stk.top().second + 1;
stk.push(make_pair(s[i],count));
prev = s[i];
if(count == k)
{
while(count--)
stk.pop();
if(!stk.empty())
prev = stk.top().first;
else
prev = '*';
}
}
}
string ans;
while(!stk.empty())
{
ans += stk.top().first;
stk.pop();
}
reverse(ans.begin(),ans.end());
return ans;
}
};
class Solution {
public:
string removeDuplicates(string s, int k) {
int i, count = 0;
stack<pair<char,int>> stk;
char prev = '*';
for(i = 0; i < s.size(); ++i)
{
if(prev != s[i])
{
count = 1;
stk.push(make_pair(s[i],count));
prev = s[i];
}
else//prev == s[i]
{
stk.top().second++;//直接+1
if(stk.top().second == k)
{
stk.pop();
if(!stk.empty())
prev = stk.top().first;
else
prev = '*';
}
}
}
string ans;
while(!stk.empty())
{
count = stk.top().second;
while(count--)
ans += stk.top().first;
stk.pop();
}
reverse(ans.begin(),ans.end());
return ans;
}
};