滑动窗口(同向的双指针)

通过 双指针的 同向移动
算法应用的场景:
满足xxx条件(计算结果,出现次数,同时包含)
最长/最短
子串 /子数组/子序列

例如:长度最小的子数组

滑动窗口 使用思路 (寻找最长)
–核心:左右指针(l,r)在起始点,r 向右逐位滑动循环

每次滑动过程中
如果 :窗内元素满足条件,r向右扩大窗口。并更新最优结果。
如果:窗内元素不满足条件,l向右缩小窗口

–r到达结尾

滑动窗口(寻找最短)
-核心:左右 双指针(l,r)在起始点,R向右逐位滑动循环
每次滑动过程中
如果:窗内元素满足条件 ,L向右缩小窗口
如果:窗内元素不满足条件,R向右扩大窗口
r到达结尾。

//最长模板
初始化 l,r,re,ans
while(右指针没有到结尾)
{
	窗口扩大,加入right指针对应的元素,更新当前的re
	while(re不满足要求)
	{
		窗口缩小,移出l对应的元素,l右移 
	 } 
	 更新最优结果 ans
	 r++; 
}

最短模板
 初始化 l,r,re,ans
 while(右指针没有到结尾){
 	窗口扩大,加入r对应的元素,更新当前的result
	 while(result满足条件)
	 {
	 	更新最优结果ans
		 窗口缩小,移出l对应的元素,l右移 
	  } 
	  r++; 
 }

click me!
n target
找出 数组中 满足其和大于等于 target长度最小的子数组

class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int l=0,r=0;
        int cursum=0;int ans=0;
        while(r<nums.size())
        {
            cursum+=nums[r];
            while(cursum>=target){
               if (r-l+1<ans||ans==0)
               ans=r-l+1;
                cursum-=nums[l];
                l++;
            }
            r++;
        }
        return ans;
    }
};

click me
给你一个字符串s ,找出其中不含有重复字符最长子串的长度。
上一题中我们 使用 curcum来维护区间的和。
在这一题中,我们要有 能判断区间是否有重复元素的东西。使用map<int,int>

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        map<char,int>mp;
        int l=0,r=0;int ans=0;
        //找最长的
        while(r<s.size())
        {
            mp[s[r]]++;
            while (mp[s[r]]>1){
                mp[s[l]]--;
                l++;
            }
            ans=max(ans,r-l+1);
            r++;
        }
        return ans;
    }
};

添加链接描述
整数数组 nums 整数k
返回子数组内 所有元素的乘积 严格小于k的个数。
在这里插入图片描述
在这里插入图片描述

对于一个符合条件的子数组,以r结尾的 小的子数组 有长度为1,2,一直到 r-l+1的长度。

class Solution {
public:
    int numSubarrayProductLessThanK(vector<int>& nums, int k) {
        int n = nums.size(), ret = 0;
        int prod = 1, i = 0;
        for (int j = 0; j < n; j++) {
            prod *= nums[j];
            while (i <= j && prod >= k) {
                prod /= nums[i];
                i++;
            }
            ret += j - i + 1;
        }
        return ret;
    }
};

作者:力扣官方题解
链接:https://leetcode.cn/problems/subarray-product-less-than-k/solutions/1463527/cheng-ji-xiao-yu-k-de-zi-shu-zu-by-leetc-92wl/
来源:力扣(LeetCode)

添加链接描述

题目可以转化成 求子数组 和为 sum-x 的最长度。

class Solution {
public:
    int minOperations(vector<int>& nums, int x) {
       int sum=0;bool flag=0;
        for (auto i:nums )sum+=i;
        
        int tar=sum-x;
        if(tar<0)return -1;
        else if (tar==0) return nums.size();
        //找小于等于最长的子数组
        int n=nums.size();int i=0;int ans=0;int cursum=0;
        for (int j=0;j<n;j++)
        {
            cursum+=nums[j];
            while(cursum>tar){
                cursum-=nums[i];
                i++;
            }
            这里略有不同,只有子数组的和为tar的时候,才更新答案
            if (i<=j&&cursum==tar)
            {ans=max(ans,j-i+1);
            flag=1;
            }
        }
        if(flag) return n-ans;
        else return -1;
    }
};

添加链接描述

在这里插入图片描述
这道题 主要 想说的是,时间复杂度的计算。
m是s的长度,n是t的长度
我一开始 认为 是 n*m.在每一次移动指针的时候,都要判断 我们选出来的区间是否还符合条件,我意识 认为 ,每次判断是o(n),也就是遍历一遍t数组的时间复杂度。
数据是1e5,我一想妥妥超时。
但实际上,我们判断的时间复杂是 t数组中,O(符号的种类),所以最多也就是128

class Solution {
    bool is_(int cnt_s[],int cnt_t[])
    {
        for (int i='A';i<='Z';i++)
        {
            if (cnt_s[i]<cnt_t[i])
            return false;
        }
        for (int i='a';i<='z';i++)
        {
            if (cnt_s[i]<cnt_t[i])
            return false;
        }
        return true;
    }
public:
    string minWindow(string s, string t) {
       int cnt_s[128],cnt_t[128];
       for (char c:t)cnt_t[c]++;
        int len=s.length();
        int j=0,i=0;int el=0,er=s.size()-1;
        bool flag=0;
        for (j=0;j<len;j++)
        {
            cnt_s[s[j]]++;
            while(i<=j&&is_(cnt_s,cnt_t))
            {
                if (j-i<er-el){
                    er=j;el=i;
                }
                flag=1;
                cnt_s[s[i]]--;
                i++;
            }
            
        }
        string tt;
        if (flag){
            
            for (int k=el;k<=er;k++)
            {
                cout<<s[k]<<" ";
                tt+=s[k];
            }

           
        }
        return tt;
    }
};

滑动窗口先整这些吧,基本的思路有了。等碰到题,不会的时候,在想吧

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/784802.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

刷题(day01)

1、leetcode485.最大连续1的个数 给定一个二进制数组 nums &#xff0c; 计算其中最大连续 1 的个数。 示例 1&#xff1a; 输入&#xff1a;nums [1,1,0,1,1,1] 输出&#xff1a;3 解释&#xff1a;开头的两位和最后的三位都是连续 1 &#xff0c;所以最大连续 1 的个数是 3.…

基于CentOS Stream 9平台搭建FRP内网穿透

内网穿透方法很多&#xff0c;本文以github上很火的frp为例 1.frp官方 文档&#xff1a;https://gofrp.org/zh-cn/docs/overview/ 1.1 下载 https://github.com/fatedier/frp/releases 选中合适的版本 2. 服务端&#xff08;服务器&#xff09;搭建frps 需要公网IP服务器 选…

假期笔记1:anaconda的安装与pycharm中的引用

1.下载安装 Download Anaconda Distribution | Anaconda 2.填个邮箱 11111.. 3.下载。有点需要时间 4.安装&#xff0c;双击&#xff0c;根据实际进行&#xff0c;记清安装路径 5。环境设置 conda -V 6.创建环境 conda create --name env_name conda create --na…

Qt文档阅读笔记-Queued Custom Type Example

此篇展示了使用Qt编写多线程程序。 概述 此案例创建一Block类&#xff0c;用于存储数据&#xff0c;并且在元对象系统中注册后&#xff0c;在多线程中进行信号与槽函数的连接中充当参数。 Block类 在元对象系统中&#xff0c;注册类&#xff0c;需要类在public部分提供默认构…

基于SSM的志愿者服务平台

基于SSM的志愿者服务平台系统主要其系统包括不同的端组成&#xff0c;前端主要包括系统用户管理、新闻数据管理、变幻图管理、志愿者管理、培训视频管理、志愿者项目管理、服务时长管理、交流分享管理、志愿者表彰管理。前台主要包括网站首页、培训视频、志愿者项目、交流分享、…

React+TS前台项目实战(二十六)-- 高性能可配置Echarts图表组件封装

文章目录 前言CommonChart组件1. 功能分析2. 代码详细注释3. 使用到的全局hook代码4. 使用方式5. 效果展示 总结 前言 Echarts图表在项目中经常用到&#xff0c;然而&#xff0c;重复编写初始化&#xff0c;更新&#xff0c;以及清除实例等动作对于开发人员来说是一种浪费时间…

C语言相关内容模块

C语言相关内容模块 1、函数指针定义方式 1、函数指针定义方式 函数指针的具体用法

最近点对问题(算法与数据结构设计)

课题内容和要求 最近点对问题&#xff0c;在二维平面上输入n个点列P。其中任一点pi&#xff08;xi&#xff0c;yi&#xff09;&#xff0c;编写程序求出最近的两个点。使用穷举法实现&#xff0c;算法复杂度O(n2)&#xff1b;优化算法&#xff0c;以O(nlog2n)实现这一问题 数…

阶段三:项目开发---民航功能模块实现:任务24:航空实时监控

任务描述 内 容&#xff1a;地图展示、飞机飞行轨迹、扇区控制。航空实时监控&#xff0c;是飞机每秒发送坐标&#xff0c;经过终端转换实时发送给塔台&#xff0c;为了飞机位置的精准度&#xff0c;传输位置的密度很大&#xff0c;在地图位置显示不明显。本次为了案例展示效…

AI系统的PyTorch:TextGrad框架基于文本梯度实现大语言模型AI系统自优化!

AI系统的PyTorch&#xff1a;TextGrad框架基于文本梯度实现大语言模型AI系统自优化&#xff01; 原创 旺知识 旺知识 2024年07月07日 16:21 广东 人工智能&#xff08;AI&#xff09;正在经历一场范式转变&#xff0c;这一转变是由系统协调多个大型语言模型&#xff08;LLMs&…

51 单片机[7]:计时器

一、定时器 1. 定时器介绍 51单片机的定时器属于单片机的内部资源&#xff0c;其电路的连接和运转均在单片机内部完成。 定时器作用&#xff1a; &#xff08;1&#xff09;用于计时系统&#xff0c;可实现软件计时&#xff0c;或者使程序每隔一固定时间完成一项操作 &#…

【零基础】学JS之APIS(基于黑马)

喝下这碗鸡汤 披盔戴甲,一路勇往直前! 1. 什么是事件 事件是在编程时系统内发生的动作或者发生的事情 比如用户在网页上单击一个按钮 2. 什么是事件监听? 就是让程序检测是否有事件产生&#xff0c;一旦有事件触发&#xff0c;就立即调用一个函数做出响应&#xff0c;也称为 注…

【人工智能】—基于成都市各区(市)县租房价格预测建模研究

引言 随着城市化进程的加速&#xff0c;人口流动日益频繁&#xff0c;租房市场作为城市生活的重要组成部分&#xff0c;其价格波动对居民生活质量和城市经济发展具有显著影响。成都市&#xff0c;作为中国西部地区的经济、文化、交通和科技中心&#xff0c;近年来吸引了大量人…

5.Python学习:面向对象

1.面向对象和面向过程的区别 以下五子棋为例&#xff1a; 2.类和实例 &#xff08;1&#xff09;类是抽象的模板&#xff0c;实例是根据模板创建出来的具体的对象 &#xff08;2&#xff09;比如人类就是一个类&#xff0c;刘亦菲就是人类的一个实例 2.1 新建类和类的实例…

王老师 linux c++ 通信架构 笔记(三)安装 xftp、

&#xff08;11&#xff09;调整 xshell 终端的字体大小&#xff0c;默认字体大小是 9 &#xff1a; &#xff08;12&#xff09; 共享文件夹 hgfs 的含义&#xff1a; &#xff08;13&#xff09;安装 xftp &#xff0c; 傻瓜式安装&#xff0c;出了修改下默认安装位置。 操作…

上位机图像处理和嵌入式模块部署(mcu项目2:串口日志记录器)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 淘宝上面有一个商品蛮好玩的&#xff0c;那就是日志记录器。说是记录器&#xff0c;其实就是一个模块&#xff0c;这个模块的输入是一个ttl串口&am…

18.动态规划之斐波那契数列模型1

1.第N个斐波那契数 1137. 第 N 个泰波那契数 - 力扣&#xff08;LeetCode&#xff09; 做题流程 1. 状态表示&#xff1a; 这道题可以【根据题目的要求】直接定义出状态表示&#xff1a; dp[i] 表示&#xff1a;第 i 个泰波那契数的值。 2. 状态转移方程&#xff1a; …

Social to Sales全链路,数说故事专享会开启出海新视角

————瞎出海&#xff0c;必出局 TikTok&#xff0c;这个充满活力的短视频平台&#xff0c;已经成为全球范围内不可忽视的电商巨头。就在6月8日&#xff0c;TikTok美区带货直播诞生了首个“百万大场”。在此之前&#xff0c;百万GMV被视为一道难以逾越的高墙。以TikTok为首的…

Zabbix分布式监控

目录 分布式监控架构 实现分布式监控的步骤 优点和应用场景 安装Zabbix_Proxy Server端Web页面配置 测试 Zabbix 的分布式监控架构允许在大规模和地理上分散的环境中进行高效的监控。通过分布式监控&#xff0c;Zabbix 可以扩展其监控能力&#xff0c;支持大量主机和设备…

Android - 云游戏本地悬浮输入框实现

一、简述 云游戏输入法分两种情况,以云化原神为例,分为 云端输入法 和 本地输入法,运行效果如下: 云端输入法本地输入法云端输入法 就是运行在云端设备上的输入法,对于不同客户端来说(Android、iPhone),运行效果一致。 本地输入法 则是运行在用户侧设备上的输入法,对…