Leetcode 1234. 替换子串得到平衡字符串 题解

题目链接:https://leetcode-cn.com/problems/replace-the-substring-for-balanced-string/
在这里插入图片描述
在这里插入图片描述
滑动窗口套模版,不说了,接着模仿去了

代码如下:

class Solution {
public:
    int balancedString(string s) {
        int n = s.size();
        int averge = n/4;
        map<char,int>hash;
        map<char,int>window;
        map<char,int>need;
        for(auto&c :s)//记录个字母出现次数
            hash[c]++;
        for(auto&p : hash){
            if(p.second>averge)//大于平均值的,肯定是要修改的,因此加入need里,
                need[p.first] = p.second-averge;//次数修改为多于平均值的次数
        }
        if(need.size() == 0)
            return 0;
        int l = 0, r = 0;
        int match = 0;
        int res = n;//取最大
        while(r<n){
            char c = s[r];
            if(need.find(c) != need.end()){//符合一定条件
                window[c]++;
                if(window[c] == need[c])//对应次数符合后,匹配数++
                    match++;
            }
            r++;
            while(match == need.size()){//匹配数与need的大小相等,表明当前窗口已经包括所有需要修改的字符了
                res = min(res,r-l);//更新窗口大小
                char c2 = s[l];
                if(need.find(c2) != need.end()){//破坏条件
                    window[c2]--;
                    if(window[c2] < need[c2])
                        match--;
                }
                l++;
            }
        }
        return res;
    }
};

猜你喜欢

转载自blog.csdn.net/weixin_42396397/article/details/105893914