力扣打卡day06——滑动窗口最大值、最小覆盖子串

239. 滑动窗口最大值 - 力扣(LeetCode)

思路:

自己定义构造单调队列,队列中的首部就是每个窗口的最大元素,每次弹出元素的时候,判断要弹出元素是不是队列里面的最大值(就是队列的首部),加入队列,比加入元素小的全部都弹出。

代码:

主要就是用res 记录每个窗口的最大值,在计算第一个窗口的最大值,最后进行循环即可。

复制代码
,class Mydeque{
       //自己定义构造单调队列
         Deque<Integer> deque=new LinkedList<>();

        //弹出队列,判断要弹出元素是不是队列里面的最大值
        void poll(int val){
            if(!deque.isEmpty()&&val==deque.peek()){
                deque.poll();
            }
        }
        //加入队列,比元素小的全部都弹出
         void add(int val){
            while(!deque.isEmpty()&&val>deque.getLast()){
                    deque.removeLast();
            }
            deque.add(val);
         }
         //队列的顶部就是最大元素
         int peek(){
          return   deque.peek();
         }
}

class Solution {
    
   
    public int[] maxSlidingWindow(int[] nums, int k) { 
          int n=nums.length;
          int len=n-k+1; 
          int []res=new int[len];//每个窗口的最大值
          int  rar=0; //记录下标
          Mydeque mydeque=new Mydeque();
          //前三个元素加入
          for(int i=0;i<k;i++){
             mydeque.add(nums[i]);
          }
          res[rar++]=mydeque.peek();//第一个窗口最大值

          for(int i=k;i<n;i++){
            //滑动窗口移除最前面的元素
             mydeque.poll(nums[i-k]);
             //滑动窗口加入最后面的元素
             mydeque.add(nums[i]);
             //记录对应的最大值
             res[rar++]=mydeque.peek();
          }
          return res;

    }
}

作者:﹋少年つ
链接:https://leetcode.cn/problems/sliding-window-maximum/solutions/3800920/jin-ri-da-qia-jia-you-by-2174854139-bs3g/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

76. 最小覆盖子串 - 力扣(LeetCode)

复制代码
class Solution {
     public String minWindow(String s, String t) {
        //特殊情况进行判断
        if (s==null||s.isEmpty()||t.isEmpty()||t==null){
            return "";
        }
        //记录t的大小和次数
        Map<Character,Integer> need=new HashMap<>();
        //记录窗口的大小和次数
        Map<Character,Integer> window=new HashMap<>();
        int left=0,right=0; //左右指针
        int  strnumber=0; //匹配的个数
        int   minlen=Integer.MAX_VALUE;  //最小长度
        int   start=0; //最短起始指针
        //进行t的初始化
        for(char c:t.toCharArray()) {
            need.put(c,need.getOrDefault(c,0)+1);
        }
        while(right<s.length()){
            char r=s.charAt(right);
            right++;
            //更新窗口内字符的计数
            if(need.containsKey(r)){
                window.put(r, window.getOrDefault(r,0)+1);
                if (need.get(r).equals(window.get(r))) {
                    strnumber++;
                }
            }
            //当窗口内的字符已经完全包含了 t 中的所有字符时
            while (strnumber==need.size()){
                // 更新最小窗口的起始位置和长度
                if (right-left<minlen){
                   start=left;
                   minlen=right-left;
                }
                  // 缩小窗口,移动左边界
                char l=s.charAt(left);
                if (window.containsKey(l)){
                    window.put(l,window.get(l)-1);
                    if (window.get(l)<need.get(l)) {
                        strnumber--;
                    }
                }
                left++;
            }

        }
        return  minlen==Integer.MAX_VALUE? "": s.substring(start,start+minlen);
    }
}
相关推荐
IronMurphy1 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬1 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership2 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826522 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa2 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!2 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
Beginner x_u2 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
丑八怪大丑3 小时前
Java数据结构与集合源码
数据结构
_深海凉_6 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
踩坑记录6 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode