滑动窗口编程题集合(leetcode)
创始人
2025-05-30 08:09:02

滑动窗口是双指针的一种应用,形象点说就是维护一个窗口,在窗口滑动的过程中进行窗口内数据的更新,并判断是否符合答案。初始时两个指针均指向开头,然后右指针依次向右滑动,在滑动的过程中需要收缩的时候进行左指针的移动,当右指针移出的时候结束循环即可。

滑动窗口法常用于求解满足某种条件的某段连续区间的最短或最长子序列(一般为子数组、子字符串等),如:
1)最小摘要
2)和大于给定目标值的最短子序列
3)无重复字符的最长子串
4)有k个不同字符的子串
滑动窗口的重要性质是:窗口的左边界和右边界永远只能向右移动,而不能向左移动。这是为了保证滑动窗口的时间复杂度是 O(n)。如果左右边界向左移动的话,这叫做“回溯”,算法的时间复杂度就可能不止 O(n)

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

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

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。
 public int minSubArrayLen(int target, int[] nums) {int i=0,sum=0,result=Integer.MAX_VALUE;for(int j=0;j=target){int m = j - i + 1;sum=sum-nums[i];i++;result=Math.min(result,m);}}if(result==Integer.MAX_VALUE)return 0;return result;}
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
  public int lengthOfLongestSubstring(String s) {if(s==null||s.equals(""))return 0;int i=0,max=0;HashSet hashSet=new HashSet<>();for(int j=0;j
给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 。
输入:nums = [1,2,3,1], k= 3 输出:true
    public boolean containsNearbyDuplicate(int[] nums, int k) {int i=0;HashSet hashSet=new HashSet<>();for(int j=0;jk){hashSet.remove(nums[i]);i++;}if(!hashSet.contains(nums[j])){hashSet.add(nums[j]);}elsereturn true;}return false;}

相关内容

热门资讯

全球媒体聚焦 | 美媒:“冰雪... (来源:千龙网)美国《旅行与旅游世界》网站12月12日发表文章,关注冰雪运动在中国的日益盛行是如何助...
海南自由贸易港海关特殊监管区域... 转自:新华社新华社海口12月13日电(记者刘邓、吴茂辉)记者从海口海关获悉,近日,一台船用发动机的保...
27载照顾公婆 石景山白慧霞入... 转自:北京青年报客户端12月13日,北京青年报记者从石景山区获悉,该区八角街道杨庄北区社区居民白慧霞...
张毓强父子的资本“炼金术”:振... 转自:华夏能源网文|华夏能源网一家6年前在港股市值不足22亿元的公司,如今以近400亿元的估值冲击A...
年轻人涌入高校买羽绒服! 12月12日“人大899元书记严选羽绒服卖断货”登上热搜阅读量突破两千万讨论互动量过万近日,多所高校...