力扣1234.替换子串得到平衡字符串

力扣1234.替换子串得到平衡字符串

  • 由题意可知 超过n/4的字母是一定要替换的

    • 所以只要找到一段包含超过n/4个字母的最小区间即可
    • 转换为去除这个最小区间后 4种字母的出现频率都<=n/4
cpp 复制代码
  class Solution {
  public:
      int balancedString(string s) {
          unordered_map<char,int> cnt;
          int n = s.size(),m = n/4,res=n;
          for(int i=0;i<s.size();i++)
              cnt[s[i]] ++;
          //如果已经满足要求 直接return
          if (cnt['Q'] == m && cnt['W'] == m && cnt['E'] == m && cnt['R'] == m)
              return 0;
          //枚举右端点
          for(int i=0,j=0;i<n;i++)
          {
              //放入区间 同时删去
              cnt[s[i]] --;
              //满足要求
              while (cnt['Q'] <= m && cnt['W'] <= m && cnt['E'] <= m && cnt['R'] <= m)
              {
                  res = min(res,i-j+1);
                  //左端点加回来
                  cnt[s[j++]]++;
              }
          }
          return res;
      }
  };
相关推荐
Henray202412 小时前
最低公共祖先 LCA
java·面试
shehuiyuelaiyuehao13 小时前
关于进程和线程的关系
java·开发语言
河阿里13 小时前
SpringBoot:项目启动速度深度优化
java·spring boot·后端
AaronCos13 小时前
弄懂java泛型中的extends和super
java·开发语言
用户2395261801013 小时前
别再 new 满天飞了!一文搞懂工厂模式,程序员终于不用手搓对象了 😆
java
阿丰资源13 小时前
基于SpringBoot的企业客户管理系统(附源码)
java·spring boot·后端
yongui4783413 小时前
基于 GA 优化的 BP 神经网络算法分析与 MATLAB 实现
神经网络·算法·matlab
两年半的个人练习生^_^13 小时前
SpringBoot 项目使用 Jasypt 实现配置文件敏感信息加密
java·spring boot·后端
JAVA学习通13 小时前
开云集致 Java开发 实习 一面
java·开发语言
阿旭超级学得完14 小时前
C++11(初始化)
java·开发语言·数据结构·c++·算法