力扣100题——子串

和为K的子数组

题目

560. 和为 K 的子数组 - 力扣(LeetCode)

思路

以一个数为基准,从这个数往后开始遍历相加,如果sum==k则count++。只要保证基准数不重复,就不会出现重复的子数组。

代码

java 复制代码
class Solution {
     public int subarraySum(int[] nums, int k) {
        int count = 0;
        for(int i=0;i<nums.length;i++){
            int sum = 0;
            for(int j=i;j>=0;j--){
                sum = sum + nums[j];
                if(sum==k){
                    count++;
                }
            }
        }
        return count;
     }
}

滑动窗口最大值

题目

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

思路

用双向链表保证最大值始终是链表第一个元素,每次滑动窗口的时候都把最大值保存在maxList中,最后将maxList转成数组即可

代码

java 复制代码
public int[] maxSlidingWindow(int[] nums, int k) {
        LinkedList<Integer> list = new LinkedList<>();
        LinkedList<Integer> maxList = new LinkedList<>();
        list.add(nums[0]);
        for(int i=1;i<k;i++){
            if(nums[i]<list.getFirst()){
                list.addLast(nums[i]);
            }else{
                list.addFirst(nums[i]);
            }
        }
        maxList.add(list.getFirst());
        for(int i=k;i<nums.length;i++){
            int x = nums[i-k];
          //  System.out.println(list.contains(x)+"   "+(i-k));
           list.remove((Integer) i-k);
           if(nums[i]<list.getFirst()){
               list.addLast(nums[i]);
           }else{
               list.addFirst(nums[i]);
           }
            maxList.add(list.getFirst());
        }
        int []ans = new int[maxList.size()];
        for(int i=0;i<maxList.size();i++){
            ans[i] = maxList.get(i);
        }
        return ans;
    }

最小覆盖子串

题目

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

思路

首先可以使用类似双指针的想法去理解,r,l和从最左端开始出发,r不断右移,当当前l和r的区间包括了t中所有字符时,记录下当前的l和r。再将l右移,重复上面的步骤,遍历完整个s串。

关键就在于怎么判断前l和r的区间包括了t中所有字符,可以使用两个数组分别记录当前区间中每个字符的个数和t中每个字符的个数。当每个字符个数相同或当前区间大于t中每个字符个数时,即为覆盖。

代码

java 复制代码
public String minWindow(String S, String t) {
        char[] s = S.toCharArray();
        int m = s.length;
        int ansLeft = -1;
        int ansRight = m;
        int left = 0;
        int[] cntS = new int[128]; 
        int[] cntT = new int[128]; 
        for (char c : t.toCharArray()) {
            cntT[c]++;
        }
        for (int right = 0; right < m; right++) { 
            cntS[s[right]]++; 
            while (isCovered(cntS, cntT)) { 
                if (right - left < ansRight - ansLeft) { 
                    ansLeft = left; 
                    ansRight = right;
                }
                cntS[s[left++]]--; // 左端点字母移出子串
            }
        }
        return ansLeft < 0 ? "" : S.substring(ansLeft, ansRight + 1);
    }

    private boolean isCovered(int[] cntS, int[] cntT) {
        for (int i = 'A'; i <= 'Z'; i++) {
            if (cntS[i] < cntT[i]) {
                return false;
            }
        }
        for (int i = 'a'; i <= 'z'; i++) {
            if (cntS[i] < cntT[i]) {
                return false;
            }
        }
        return true;
    }
相关推荐
格林威42 分钟前
常规线扫描镜头有哪些类型?能做什么?
人工智能·深度学习·数码相机·算法·计算机视觉·视觉检测·工业镜头
程序员莫小特3 小时前
老题新解|大整数加法
数据结构·c++·算法
小刘max4 小时前
深入理解队列(Queue):从原理到实践的完整指南
数据结构
过往入尘土4 小时前
服务端与客户端的简单链接
人工智能·python·算法·pycharm·大模型
zycoder.4 小时前
力扣面试经典150题day1第一题(lc88),第二题(lc27)
算法·leetcode·面试
Dream it possible!4 小时前
LeetCode 面试经典 150_哈希表_存在重复元素 II(46_219_C++_简单)
leetcode·面试·散列表
蒙奇D索大4 小时前
【数据结构】考研数据结构核心考点:二叉排序树(BST)全方位详解与代码实现
数据结构·笔记·学习·考研·算法·改行学it
洲覆4 小时前
C++ 模板、泛型与 auto 关键字
开发语言·数据结构·c++
MoRanzhi12034 小时前
15. Pandas 综合实战案例(零售数据分析)
数据结构·python·数据挖掘·数据分析·pandas·matplotlib·零售
智驱力人工智能5 小时前
工厂抽烟检测系统 智能化安全管控新方案 加油站吸烟检测技术 吸烟行为智能监测
人工智能·算法·安全·边缘计算·抽烟检测算法·工厂抽烟检测系统·吸烟监测