力扣笔记----滑动窗口 3. 无重复字符的最长子串 209. 长度最小的子数组

Posted zisuiii

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了力扣笔记----滑动窗口 3. 无重复字符的最长子串 209. 长度最小的子数组相关的知识,希望对你有一定的参考价值。

目录

T1 给定一个含有 n 个正整数的数组和一个正整数 target 。

T209 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。


T1 给定一个含有 n 个正整数的数组和一个正整数 target 。

找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/minimum-size-subarray-sum

思路:在数组中找连续xxx,所以

使用滑动窗口方法进行求解.

本题为求和(sum)大于目标值,所以可以直接从头遍历数组循环相加直到大于目标值。

此时,记录下当前连续元素个数(并与之后符合条件的连续元素个数进行比较取最小值)。

然后用前面所求的和减去左边第一位,判断sum是否仍然大于目标值,如果是 则继续减第二位,直到sum小于目标值。此时的 符合条件的最小连续子数组 是i = n的时候的最短的一个。

注 sum -= nums[left++];先计算sum的值后再进行left++。

//209长度最小的子数组

class Solution 

    public int minSubArrayLen(int target, int[] nums) 

        int left = 0;

        int res = Integer.MAX_VALUE;

        int sum = 0;

        for (int right = 0; right < nums.length; right++) 

            sum += nums[right];

            while (sum>=target) 

                res = Math.min(right - left + 1, res);

                sum -= nums[left++];

            

        

        return res == Integer.MAX_VALUE ? 0:res;

    

T209 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:

输入: s = "abcabcbb"

输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:

输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
示例 4:

输入: s = ""
输出: 0

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters

思路: 个人感觉滑动窗口的题比较类似。此题需要一个指针(比移除map数据方便?)

这道题与上道题的区别主要是判定条件:

此题判定条件是:存入窗口中的元素(map中的)是否包含下一个元素。如果不包含则直接添加到窗口中,如果是,则需要把指针移到指针所在位置后的一个这个元素上。 

上道题则是通过判断sum是否大于target。

class Solution 
    public int lengthOfLongestSubstring(String s) 
        int n = s.length(), ans = 0;
        Map<Character, Integer> map = new HashMap<>();
        for (int end = 0, start = 0; end < n; end++) 
            char alpha = s.charAt(end);
            if (map.containsKey(alpha)) 
                start = Math.max(map.get(alpha), start);
            
            ans = Math.max(ans, end - start + 1);
            map.put(s.charAt(end), end + 1);
        
        return ans;
    


作者:guanpengchn
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/solution/hua-jie-suan-fa-3-wu-zhong-fu-zi-fu-de-zui-chang-z/
来源:力扣(LeetCode)


 

以上是关于力扣笔记----滑动窗口 3. 无重复字符的最长子串 209. 长度最小的子数组的主要内容,如果未能解决你的问题,请参考以下文章

力扣笔记----滑动窗口 3. 无重复字符的最长子串 209. 长度最小的子数组

力扣笔记----滑动窗口 3. 无重复字符的最长子串 209. 长度最小的子数组

力扣.求无重复字符的最长子串 C++ 滑动窗口

力扣3. 无重复字符的最长子串

滑动窗口问题复习

滑动窗口:无重复字符的最长子串