滑动窗口经典问题(算法村第十六关白银挑战)

最长字串专题

无重复字符的最长子串

3. 无重复字符的最长子串 - 力扣(LeetCode)

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

示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3

示例 2:

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

示例 3:

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

提示:

  • 0 <= s.length <= 5 * 104
  • s 由英文字母、数字、符号和空格组成
滑动窗口+HashMap
  1. start不动,end向后移动
  2. end遇到重复字符时,若重复字符的上一个位置比start靠右,则start更新为重复字符的上一个位置 + 1(即子串从不重复的位置重新开始统计)。同时记录最长字串的长度
  3. hashMap的key记录字符,value记录重复字符的最新下标。
public int lengthOfLongestSubstring(String s)
{
    int start = 0;
    int ans = 0;
    HashMap<Character, Integer> hashMap = new HashMap<Character, Integer>();

    for (int end= 0; end < s.length(); end++)
    {
        char c =  s.charAt(end);

        if ((hashMap.containsKey(c)))
            start = Math.max(hashMap.get(c) + 1, start);

        hashMap.put(c, end);
        ans = Math.max(ans, end - start + 1);
    }

    return ans;
}

参考题解:3. 无重复字符的最长子串 - 力扣(LeetCode)

至多包含两个不同字符的最长子串

159. 至多包含两个不同字符的最长子串 - 力扣(LeetCode)

给你一个字符串 s ,请你找出 至多 包含 两个不同字符 的最长子串,并返回该子串的长度。

示例 1:

输入:s = "eceba"
输出:3
解释:满足题目要求的子串是 "ece" ,长度为 3

示例 2:

输入:s = "ccaabbb"
输出:5
解释:满足题目要求的子串是 "aabbb" ,长度为 5
基于HashMap的滑动窗口
public int lengthOfLongestSubstringTwoDistinct(String s)
{
    if (s.length() < 3)
        return s.length();

    // hashMap 中的字符 -> 字符在滑动窗口中最靠右的位置
    HashMap<Character, Integer> hashMap = new HashMap<Character, Integer>();
    int ans = 2;

    for (int left = 0, right = 0; right < s.length(); right++)
    {
        hashMap.put(s.charAt(right), right);

        //滑动窗口中不同字符超过2个(应维持在2个及以内)
        if(hashMap.size() > 2)
        {
            //提取滑动窗口中最靠左的字符的位置
            int t = Collections.min(hashMap.values());
            //删除在滑动窗口中删除该字符
            hashMap.remove(s.charAt(t));
            //更新滑动窗口中左侧指针
            left = t + 1;
        }

        ans = Math.max(ans, right - left + 1);
    }

    return ans;
}

参考题解:159. 至多包含两个不同字符的最长子串 - 力扣(LeetCode)

拓展题

340. 至多包含 K 个不同字符的最长子串 - 力扣(LeetCode)

给你一个字符串 s 和一个整数 k ,请你找出 至多 包含 k不同 字符的最长子串,并返回该子串的长度。

public int lengthOfLongestSubstringKDistinct(String s, int k)
{
    if (s.length() < k)
        return s.length();

    // hashMap 中的字符 -> 字符在滑动窗口中最靠右的位置
    HashMap<Character, Integer> hashMap = new HashMap<Character, Integer>();
    int ans = k;

    for (int left = 0, right = 0; right < s.length(); right++)
    {
        hashMap.put(s.charAt(right), right);

        //滑动窗口中不同字符超过k个(应维持在k个及以内)
        if(hashMap.size() > k)
        {
            //提取滑动窗口中最靠左的字符的位置
            int t = Collections.min(hashMap.values());
            //删除在滑动窗口中删除该字符
            hashMap.remove(s.charAt(t));
            //更新滑动窗口中左侧指针
            left = t + 1;
        }

        ans = Math.max(ans, right - left + 1);
    }

    return ans;
}

长度最小的子数组

209. 长度最小的子数组 - 力扣(LeetCode)

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

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

示例 1:

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。

示例 2:

输入:target = 4, nums = [1,4,4]
输出:1

示例 3:

输入:target = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

提示:

  • 1 <= target <= 109
  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 105

大小可变的滑动窗口

这里用队列的结构来演示
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

public int minSubArrayLen(int target, int[] nums)
{
    int ans = Integer.MAX_VALUE;
    int sum = 0;

    for (int left = 0, right = 0; right < nums.length; right++)
    {
        //滑动窗口向右延伸
        sum += nums[right];

        //窗口中所有元素之和>=target时,记录长度,并收缩窗口左侧
        while (sum >= target)
        {
            ans = Math.min(ans, right - left + 1);
            //收缩
            sum -= nums[left];
            left++;
        }
    }

    //存在[nums的所有元素之和 < target]的情况,这种情况下ans无法更新
    return ans == Integer.MAX_VALUE ? 0 : ans;
}

盛最多水的容器

11. 盛最多水的容器 - 力扣(LeetCode)

给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0)(i, height[i])

找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。

**说明:**你不能倾斜容器。

示例 1:

img

输入:[1,8,6,2,5,4,8,3,7]
输出:49 
解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49

示例 2:

输入:height = [1,1]
输出:1

提示:

  • n == height.length
  • 2 <= n <= 105
  • 0 <= height[i] <= 104

向内收缩

盛水容量(面积) = 短板高度 * 两板距离。初始化一个板在最左,一个板在最右。向内收缩的过程中,两板距离一定减小,收缩短板一侧可能使短板变长板,原来的长板成为新的短板,从而使面积增大;但收缩长板一侧并不能改变原来的短板,甚至可能会使长板变短板,导致面积进一步减小。

所以我们只有在遍历的过程中,不断收缩短板一侧即可,同时记录最大盛水容量(面积)

public int maxArea(int[] height)
{
    int left = 0, right = height.length - 1;
    int area = 0;

    while (left < right)
    {
        area =  height[left] < height[right] ?
                Math.max(area, (right - left) * height[left++]) :
                Math.max(area, (right - left) * height[right--]);
    }

    return area;
}

寻找字串异位词

字符串的排列

567. 字符串的排列 - 力扣(LeetCode)

给你两个字符串 s1s2 ,写一个函数来判断 s2 是否包含 s1 的排列。如果是,返回 true ;否则,返回 false

换句话说,s1 的排列之一是 s2子串

示例 1:

输入:s1 = "ab" s2 = "eidbaooo"
输出:true
解释:s2 包含 s1 的排列之一 ("ba").

示例 2:

输入:s1= "ab" s2 = "eidboaoo"
输出:false

提示:

  • 1 <= s1.length, s2.length <= 104
  • s1s2 仅包含小写字母
大小固定的滑动窗口

参考题解:567. 字符串的排列 - 力扣(LeetCode)

public boolean checkInclusion(String s1, String s2)
{
    //countS1用于统计s1中各字母的出现次数
    int[] countS1 = new int[26];
    for (int i = 0; i < s1.length(); i++)
        countS1[s1.charAt(i) - 'a']++;

    //countS2用于统计滑动窗口(大小固定)中各字母出现次数
    int[] countS2 = new int[26];

    int left = 0, right = 0;
    while (right < s2.length())
    {
        //窗口移动
        countS2[s2.charAt(right) - 'a']++;
        right++;

        //判断依据:窗口内字母的出现次数等于s1中字母的出现次数
        if (Arrays.equals(countS1, countS2))
            return true;

        //滑动窗口中的元素数量超过限定值的一个
        //删去最左侧的元素
        if (right - left == s1.length())
        {
            countS2[s2.charAt(left) - 'a']--;
            left++;
        }
    }

    return false;
}

找到字符串中所有字母异位词

438. 找到字符串中所有字母异位词 - 力扣(LeetCode)

给定两个字符串 sp,找到 s 中所有 p异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。

异位词 指由相同字母重排列形成的字符串(包括相同的字符串)。

示例 1:

输入: s = "cbaebabacd", p = "abc"
输出: [0,6]
解释:
起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。
起始索引等于 6 的子串是 "bac", 它是 "abc" 的异位词。

示例 2:

输入: s = "abab", p = "ab"
输出: [0,1,2]
解释:
起始索引等于 0 的子串是 "ab", 它是 "ab" 的异位词。
起始索引等于 1 的子串是 "ba", 它是 "ab" 的异位词。
起始索引等于 2 的子串是 "ab", 它是 "ab" 的异位词。

提示:

  • 1 <= s.length, p.length <= 3 * 104
  • sp 仅包含小写字母
用一个list记录索引即可
public List<Integer> findAnagrams(String s, String p)
{
    //countS1用于统计p中各字母的出现次数
    int[] countS1 = new int[26];
    for (int i = 0; i < p.length(); i++)
        countS1[p.charAt(i) - 'a']++;

    //countS2用于统计滑动窗口(大小固定)中各字母出现次数
    int[] countS2 = new int[26];

    int left = 0, right = 0;
    ArrayList<Integer> ans = new ArrayList<>();

    while (right < s.length())
    {
        //窗口移动
        countS2[s.charAt(right) - 'a']++;
        right++;

        if (Arrays.equals(countS1, countS2))
            ans.add(left);

        //滑动窗口中的元素数量超过限定值的一个
        //删去最左侧的元素
        if (right - left == p.length())
        {
            countS2[s.charAt(left) - 'a']--;
            left++;
        }
    }

    return ans;
}

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

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

相关文章

Stable Diffusion 模型下载:RealCartoon3D - V14

文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八案例九案例十下载地址模型介绍 RealCartoon3D 是一个动漫卡通混合现实风格的模型,具有真实卡通的 3D 效果,当前更新到 V14 版本。 RealCartoon3D 是我上传的第一个模型。我仍在学习这些东西,但…

有趣的CSS - 按钮文字上下滑动

目录 整体效果核心代码html 代码css 部分代码 完整代码如下html 页面css 样式页面渲染效果 整体效果 这个按钮效果主要使用 :hover 伪选择器以及 transition 过渡属性来实现两个子元素上下过渡的效果。 此效果可以在主入口按钮、详情或者更多等按钮处使用&#xff0c;增加一些鼠…

Protainer

Protainer 介绍 Portainer 是一款轻量级的应用&#xff0c;它提供了图形化界面&#xff0c;用于方便地管理Docker环境&#xff0c;包括单机环境和集群环境。 官网 protainer 安装 docker run -d -p 8000:8000 -p 9000:9000 --name portainer --restartalways -v /var/r…

【Linux】Linux权限(下)

Hello everybody!在上一篇文章中&#xff0c;权限讲了大部分内容。今天继续介绍权限剩下的内容&#xff0c;希望大家看过这篇文章后都能有所收获&#xff01; 1.更改文件的拥有者和所属组 对于普通用户&#xff0c;文件的拥有者和所属组都无权修改。 、 、 但root可以修改文件…

嵌入式软件设计方式与方法

1、嵌入式软件与设计模式 思从深而行从简 软件开发&#xff0c;难的不是编写软件&#xff0c;而是编写功能正常的软件。软件工程化才能保证软件质量和项目进度&#xff0c;而设计模式使代码开发真正工程化&#xff0c;设计模式是软件工程的基石。 所谓设计模式就是对常见问题的…

【django】建立python虚拟环境-20240205

1.确保已经安装pip3 install venv 2.新建虚拟环境 python -m venv myenv 3.安装虚拟环境的依赖包 pip install … 4.激活虚拟环境 cd myenv cd Scripts activate 激活activate.bat并进入虚拟环境 进入虚拟环境后&#xff0c;命令行前面显示&#xff08;myenv&#xff0…

第二证券:风电景气度持续向好 诺和诺德推动减肥药扩产

昨日&#xff0c;两市股指早盘大幅下探&#xff0c;沪指盘中跌超3%创近5年新低&#xff0c;深成指、创业板指一度跌超4%&#xff0c;均创本轮调整新低&#xff1b;午后&#xff0c;三大股指在金融、酿酒等板块的带动下快速拉升&#xff0c;沪指翻红重返2700点上方&#xff0c;创…

【openwrt】MT7981 5G WiFi MAC地址不生效问题分析及解决方案

问题描述 MT7981 默认sdk 5G MAC地址根据2.4G MAC地址随机生成,我们写到Factory区域的值不生效 问题分析 查看EEPROM MAC位置 查看MTK EEPROM文档MT7981_EEPROM_Content_Introduction_V10_20211207.pdf可以看到EEPROM里面有两个位置可以存放MAC,0x04~0x09 和0x0a~0x0f 查看…

WINDOWS搭建NFS服务器

下载并安装 Networking Software for Windows 启动配置 找到安装目录&#xff08;如C:\Program Files\nfsd&#xff09;&#xff0c;双击nfsctl.exe&#xff0c;菜单Edit->Preferences 启动后&#xff1a; 配置Export Exports->Edit exports file 其他的几句我都删除…

第4节、电机多段转动【51单片机+L298N步进电机系列教程】

↑↑↑点击上方【目录】&#xff0c;查看本系列全部文章 摘要&#xff1a;本节介绍用控制步进电机三个主要参数角度、速度、方向&#xff0c;实现简单的步进电机多段控制 一、目标功能 输入多个目标角度&#xff0c;以及每个角度对应的速度&#xff0c;实现步进电机的多段多速…

C# OpenVINO 图片旋转角度检测

目录 效果 项目 代码 下载 效果 项目 代码 using OpenCvSharp; using Sdcb.OpenVINO; using System; using System.Diagnostics; using System.Drawing; using System.Linq; using System.Runtime.InteropServices; using System.Security.Cryptography; using System.Te…

讯飞星火3.5API接入指南

概述 讯飞星火大模型拥有跨领域的知识和语言理解能力&#xff0c;完成问答对话和文学创作等任务。持续从海量文本数据和大规模语法知识中学习进化&#xff0c;实现从提出问题、规划问题到解决问题的全流程闭环。 API调用流程 步骤一.资源包申请 登录讯飞星火平台&#xff0…

05-编码篇-H264文件分析

通过前面的分析&#xff0c;我们可以看出常规情况下&#xff0c;是将视频以帧的单位进行处理&#xff0c;比如I帧&#xff0c;P帧&#xff0c;B帧等。 但是这些帧是如何以文件方式保存的呢&#xff0c;这节我们主要对H264的保存方式作一个了解。 一帧图片通过编码后&#xff0c…

Matlab:利用1D-CNN(一维卷积神经网络),分析高光谱曲线数据或时序数据

1DCNN 简介&#xff1a; 1D-CNN&#xff08;一维卷积神经网络&#xff09;是一种特殊类型的卷积神经网络&#xff0c;设计用于处理一维序列数据。这种网络结构通常由多个卷积层和池化层交替组成&#xff0c;最后使用全连接层将提取的特征映射到输出。 以下是1D-CNN的主要组成…

【防止重复提交】Redis + AOP + 注解的方式实现分布式锁

文章目录 工作原理需求实现1&#xff09;自定义防重复提交注解2&#xff09;定义防重复提交AOP切面3&#xff09;RedisLock 工具类4&#xff09;过滤器 请求工具类5&#xff09;测试Controller6&#xff09;测试结果 工作原理 分布式环境下&#xff0c;可能会遇到用户对某个接…

thinkphp6入门(17)-- 网站开发中session、cache、cookie的区别

Session&#xff08;会话&#xff09;: 定义&#xff1a; Session是一种用于在服务器端存储用户信息的机制&#xff0c;以跟踪用户的状态。 数据存储位置&#xff1a; 存储在服务器端&#xff0c;可以存在于内存、数据库或文件系统中。 生命周期&#xff1a; 存在于用户访问应…

#Z0458. 树的中心2

题目 代码 #include <bits/stdc.h> using namespace std; struct ff {int z,len; }; vector<ff> vec[300001]; int n,u,v,w,dp[300001][2],ans 1e9; void dfs(int x,int fa) {for(int i 0;i < vec[x].size();i){ff son vec[x][i];if(son.z ! fa){dfs(son.z,…

CentOS镜像如何下载?在VMware中如何安装?

一、问题 CentOS镜像如何下载&#xff1f;在VMware中如何安装&#xff1f; 二、解决 1、CentOS镜像的下载 &#xff08;1&#xff09;官方网站 The CentOS Project &#xff08;2&#xff09;官方中文官网 CentOS 中文 官网 &#xff08;3&#xff09;选择CentOS Linux…

中序遍历线索化二叉树以及最终实现结果

中序遍历线索化二叉树思路分析 void InOrderCuleTree(node* root) {if(root null){cout<<结点为空<<endl ;return;}node* tmpnode root;while(tmpnode不为空){ //先找到左边的第一个线索化节点&#xff0c;并进行打印while(tmpnode.lefttag!1){tmpnode tmpnode…

物联网ARM开发-STM32之RTC浅谈

RTC 一.RTC简单介绍 RTC好比我们用来记录时间的一个钟表&#xff0c;他里面有年月日&#xff0c;还可以记录星期&#xff0c;小时&#xff0c;分钟等。是Real Time Clock的缩写&#xff0c;译为实时时钟&#xff0c;本质上是一个独立的定时器。 1. 1 与通用定时器的区别 可以…