首页 > 其他分享 >滑动窗口

滑动窗口

时间:2022-09-07 23:23:08浏览次数:77  
标签:窗口 int subLength second fruits 滑动 total first

长度最小的子数组

题目链接

暴力解法

使用两个for循环,第一层循环移动数组的起始位置,第二层循环移动数组的终止位置,时间复杂度O(n^2)。

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int s;
        int result = INT_MAX;
        int subLength;
        for(int i = 0; i < nums.size(); i++) {
            s = 0;
            for(int j = i; j < nums.size(); j++) {
                s += nums[j];
                if(s >= target) {
                    subLength = j-i+1;
                    result = subLength<result ? subLength :result;  //s>=target后不能马上就返回subLength,要继续找到满足条件的最小长度
                }
            }
        }
        return result == INT_MAX ? 0 :result;  //如果都不符合条件,即result没有被赋值,则返回0
    }
};

 滑动窗口

    ——学自“代码随想录”

滑动窗口,就是不断的调节子序列的起始位置和终止位置,从而得出我们要想的结果

暴力解法实际上也是滑动窗口的一种,现在想办法看是否能在一个for循环中进行窗口的滑动。

1、如果一次循环中,固定起始位置,移动终止位置,则与暴力解法类似

2、如果一次循环中,固定终止位置,移动起始位置:
     1)s<target,后移终止位置
     2)  s>=target,后移起始位置

将2翻译为代码:

int i=0;  //i指向起始位置,j指向终止位置
for(int j=0; j<nums.size(); j++) {
    s += nums[j];
while(s >= target) {
subLength = j-i+1; result = subLength < result ? subLength : result; s -= nums[i++]; //不是只i++,而是把num[i]移除s中
} }

相关题目

水果成篮

题目链接

剖解题意:连续采摘,最大区间

代码:

 

class Solution {
public:
    int totalFruit(vector<int>& fruits) {
        int i = 0; //起始位置
	int subLength; //每一次的采摘水果量
	int total = INT_MIN; //最大的采摘水果量
        int first = -1,second = -1; //记录水果的第一种和第二种种类 
	int j; //终止位置 
	    for(j = 0; j < fruits.size(); j++) {
		    if(first == -1) {
			    first = fruits[j];  
		    }
		    if(fruits[j] != first && fruits[j] != second) {  //出现第三种水果,此次采摘结束,重新定义采摘起始点
			    if(second == -1) {
				    second = fruits[j];
				continue;
			} 
			subLength = j-i;  //记录当前采摘水果量 
			total = total < subLength ? subLength : total;  //更新total,使total保持为最大结果
			i = j-1;    
			while(fruits[i] == fruits[i-1]) {
				i--;
			}                  //从后往前查找新的采摘起始点,使现在的采摘区间中只有两种水果
			first = fruits[i];
			second = fruits[j];  //重新记录两种水果
		} 
	} 
	subLength = j-i;
	total = total < subLength ? subLength : total;    //退出循环后,还需要记录最后一次的结果
	return total;
    }
};

 

 代码的优化:

——思路来源于LeetCode “Link”

1、上述的代码在出现第三个水果后,i从j-1开始寻找下一次采摘的初始位置,可以用一个变量存储这个位置,省去每次查找的过程

2、退出循环后的代码使可读性下降

class Solution {
public:
    int totalFruit(vector<int>& fruits) {
        int i = 0,j; //起始位置和终止位置 
	    int subLength; 
	    int total = INT_MIN;
        int first = 0,second = 0; //第一种水果和第二种水果的起始索引 
	    int t = 0;  //下一次的第一个篮子的水果的起始索引 
	    for(j = 0; j < fruits.size(); j++) {
	    	if(fruits[j] != fruits[first] && fruits[j] != fruits[second]) {
	    		if(first != second) {  //出现第三种水果 
					first = t; 
				 }
				 second = j;
			}
			if(fruits[t] != fruits[j]) {
				t = j;
			}
			subLength = j-first+1;
			total = total < subLength ? subLength : total; 	
	} 
	return total;
    }
};

 

标签:窗口,int,subLength,second,fruits,滑动,total,first
From: https://www.cnblogs.com/ynldaya/p/16667689.html

相关文章

  • 12.3窗口切换select框和iframe框
    fromseleniumimportwebdriverfromselenium.webdriver.common.byimportByimporttimedriver=webdriver.Chrome()driver.get('http://www.baidu.com')driver.maximiz......
  • P1502 窗口的星星
    目录题目描述分析代码题目描述平面上有n个有权点,有一个矩阵能框住最大的和,详情请看题面分析首先,我们考虑如何知道两颗星星可以在同一窗户内。显然,我们可以直接判断,......
  • JS获取屏幕分辨率及当前窗口宽高等数据
    document.body.clientWidth==>BODY对象宽度document.body.clientHeight==>BODY对象高度document.documentElement.clientWidth==>可见区域宽度document.documentElem......
  • 【WPF】更改WPF桌面应用程序的 启动窗口(StartupUri或Startup)
    WPF更改StartupUri方式StartupUri指定WPF应用程序启动窗口,默认为MainWindow窗口。修改方式:(1)直接修改StartupUri属性,例如:StartupUri="TestWindow.xam“"在login项目的......
  • Flink 双流联结——窗口联结(Window Join)
    对于两条流的合并,很多情况我们并不是简单地将所有数据放在一起,而是希望根据某个字段的值将它们联结起来,“配对”去做处理。例如用传感器监控火情时,我们需要将大量温度传感......
  • elementUI-el-table表头固定不滑动
    1.表格总体需要实现滚动效果,但是表头不会随之滚动2.实现方式表格外层盒子高度100%;el-table的高度也为100%,el-table标签中添加height="100%"<divclass="tableD">......
  • 带有弹出窗口的社交媒体图标(仅限 HTML + 纯 CSS)
    带有弹出窗口的社交媒体图标(仅限HTML+纯CSS)带有弹出窗口的社交媒体图标(仅限HTML+纯CSS)免费下载HTML:<ulclass="wrapper"><liclass="iconfacebook"><......
  • webForm 关闭窗口的方式
    一共有三种方式关闭弹窗:1:通过点击右上角的关闭图标. 此方式默认是没有关联到关闭事件的, 需要指定关闭窗口的方式. 通过为CloseAction属性赋值.  CloseAction属性......
  • 滑动窗口-区间长度最大值-6169. 最长优雅子数组
    问题描述给你一个由正整数组成的数组nums。如果 nums的子数组中位于不同位置的每对元素按位与(AND)运算的结果等于0,则称该子数组为优雅子数组。、返回最长......
  • 在cmd运行窗口中输入DOS命令netstat,即可查看电脑的tcp连接。
    如何查看tcp连接_百度知道 https://zhidao.baidu.com/question/202977646.html在cmd运行窗口中输入DOS命令netstat,即可查看电脑的tcp连接。具体操作请参照以下步骤。1......