leetcodeQ76最小覆盖子串

目录

思路

滑动窗口,记录区间【left,right】之间的子串覆盖没覆盖t,就是t里面的元素是不是在区间之内都找到。

有几个比较难的问题

  1. 怎么确定满足条件了,就是【left,right】之间的子串已经覆盖t,

我们可以将t用map存,这个map不会太大,因为就是大小写字母,key是字符,v是出现的次数。

然后遍历s,如果s的第i个字符在之前的map里面,则减1,当减到为0,则这个字符满足条件,然后如果t里面所有的字符都满足条件,则可以计算结果,长度为right-left+1;

之后就是左边界往右走,往右走是map里面的值加一,如果加大某一个字符的map值大于0了,则不满足条件了,right再加。

代码

java 复制代码
class Solution {
    public String minWindow(String s, String t) {
        
        Map<Character, Integer> map = new HashMap<>(80);
        int totalT =0;
        for (int i = 0; i < t.length(); i++) {
            if (map.containsKey(t.charAt(i))){
                int cnt = map.get(t.charAt(i));
                map.put(t.charAt(i), cnt+1);
            }else {
                totalT++;
                map.put(t.charAt(i),1);
            }
        }
        int left = 0;
        int right = 0;
        int result =Integer.MAX_VALUE;
        String resultString = "";
        for (right = 0; right < s.length(); right++){
            if (map.containsKey(s.charAt(right))){
                int k = map.get(s.charAt(right));
                map.put(s.charAt(right),k-1);//可以继续减,减成负值
                if (k-1 == 0){//正好满足条件
                    totalT--;
                    if (totalT == 0){
                       while (left<=right){
                           if (map.containsKey(s.charAt(left))){
                               int p = map.get(s.charAt(left));
                               if(p == 0){//减去这个就不行了
                                   if (result > (right -left +1)){ //先记录答案
                                       result = right-left+1;
                                       resultString = s.substring(left,right+1);
                                   }
                                   totalT++;//重新计算答案
                                   map.put(s.charAt(left),p+1);
                                   left++;
                                   break;
                               }
                               map.put(s.charAt(left),p+1);
                           }
                           left++;
                       }
                    }
                }
            }
        }
        //
        return resultString;
        }
}
相关推荐
Yeats_Liao11 分钟前
Spring 框架:配置缓存管理器、注解参数与过期时间
java·spring·缓存
Yeats_Liao11 分钟前
Spring 定时任务:@Scheduled 注解四大参数解析
android·java·spring
码明11 分钟前
SpringBoot整合ssm——图书管理系统
java·spring boot·spring
某风吾起16 分钟前
Linux 消息队列的使用方法
java·linux·运维
xiao-xiang19 分钟前
jenkins-k8s pod方式动态生成slave节点
java·kubernetes·jenkins
网络风云20 分钟前
golang中的包管理-下--详解
开发语言·后端·golang
取址执行30 分钟前
Redis发布订阅
java·redis·bootstrap
墨楠。32 分钟前
数据结构学习记录-树和二叉树
数据结构·学习·算法
小唐C++38 分钟前
C++小病毒-1.0勒索
开发语言·c++·vscode·python·算法·c#·编辑器
S-X-S43 分钟前
集成Sleuth实现链路追踪
java·开发语言·链路追踪