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;
    }
};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值