力扣笔记----滑动窗口 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. 长度最小的子数组