算法每日双题精讲——滑动窗口(长度最小的子数组,无重复字符的最长子串)

news2024/11/23 22:02:48

 🌟快来参与讨论💬,点赞👍、收藏⭐、分享📤,共创活力社区。 🌟

别再犹豫了!快来订阅我们的算法每日双题精讲专栏,一起踏上算法学习的精彩之旅吧!💪


目录

💯前言

💯滑动窗口的作用

💯长度最小的子数组

 题目描述: 

⭐解题思路:

🙋这个解题思路是怎么来的呢?

 代码实现(以 C++ 为例):

👀复杂度分析:

💯无重复字符的最长子串

 题目描述: 

⭐解题思路:

🙋这个解题思路是怎么来的呢?

代码实现(以 C++ 为例):

👀复杂度分析:

💯总结


💯前言

在算法的领域中,滑动窗口算法犹如一把精巧的钥匙,能够高效地开启许多数组和字符串相关问题的求解之门。今日,我们将聚焦于两道经典题目 ——“长度最小的子数组” 和 “无重复字符的最长子串”,深入领略滑动窗口算法的魅力与应用技巧。

✍当面临在给定数据结构中查找满足特定条件的子结构问题时,滑动窗口算法常常能为我们提供清晰且高效的解题思路。


💯滑动窗口的作用

滑动窗口算法借助两个同向指针来界定一个动态的 “窗口”,在数组或字符串上逐步滑动。通过不断调整窗口的大小和位置,实时监控窗口内元素的特性,从而快速定位到符合要求的子序列或子串。这种方法避免了对所有可能子结构的暴力枚举,显著提高了算法效率。


💯长度最小的子数组

题目链接👉【力扣】

题目描述: 

给定一个包含 n 个正整数的数组和一个正整数 target,找出该数组中满足其和 ≥ target 的长度最小的连续子数组,并返回其长度。若不存在符合条件的子数组,则返回 0

⭐解题思路:
  1. 初始化双指针 left 和 right,均指向数组起始位置,sum 用于记录当前窗口内元素之和,初始化为 0minLength 记录最小子数组长度,初始化为一个较大值(如 INT_MAX)。
  2. 移动 right 指针向右扩展窗口,将新元素累加到 sum 中。
  3. 当 sum ≥ target 时,尝试移动 left 指针向右收缩窗口,同时更新 sum。在此过程中,不断比较当前窗口长度与 minLength,若当前长度更小,则更新 minLength
  4. 重复步骤 2 和 3,直到 right 指针到达数组末尾。
  5. 最后,若 minLength 仍为初始值,返回 0;否则,返回 minLength
🙋这个解题思路是怎么来的呢?

我们首先最容易想到解法一:暴力求解

👇现在我们来分析以下数组:

 起初我们让left=right=0,此时sum=2,(sum为left到right之间的和)

 sum=2 < target,我们让 right++,sum变成了2+3

 

当right走到这个位置时,sum=2+3+1+2=8>target,我们计算len=right-left ,然后让left++sum减去第一个left所指的值

sum<target,我们继续让 right++

重复以上步骤,记录最小的len,直到 right<n 

 代码实现(以 C++ 为例):
class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
        int n = nums.size(); // 获取数组nums的大小

        int left = 0; // 滑动窗口的左边界指针,初始化为0
        int right = 0; // 滑动窗口的右边界指针,初始化为0
        int sum = 0; // 用于记录当前滑动窗口内元素的总和

        int len = INT_MAX; // 初始化为INT_MAX,用于记录满足条件的最小子数组长度

        // 开始移动右边界指针right来扩展滑动窗口
        while (right < n) {
            sum += nums[right]; // 将当前右边界指向的元素加入到总和sum中

            // 当当前滑动窗口内元素总和sum大于等于目标值target时
            while (sum >= target) {
                len = std::min(len, right - left + 1); // 更新最小子数组长度len,取当前窗口长度与之前记录的最小值中的较小值

                sum -= nums[left]; // 将窗口左边界对应的元素从总和sum中减去
                left++; // 左边界指针向右移动一位,尝试缩小窗口继续寻找更小的满足条件的子数组
            }

            right++; // 右边界指针向右移动一位,继续扩展窗口
        }

        // 如果len仍然是INT_MAX,说明没有找到满足条件的子数组,返回0;否则返回len
        return len == INT_MAX? 0 : len;
    }
};
👀复杂度分析:
  • 时间复杂度:O(n),其中 n 为数组长度。最坏情况下,right 指针遍历整个数组一次,left 指针最多也遍历整个数组一次。
  • 空间复杂度:O(1),仅需额外常数级别的空间存储指针和变量。

💯无重复字符的最长子串

题目链接👉【力扣】

题目描述: 

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

⭐解题思路:
  1. 初始化 left 和 right 指针指向字符串起始位置,使用 unordered_set<char> 来记录窗口内出现过的字符。
  2. 移动 right 指针向右扩展窗口,将新字符插入集合中。
  3. 若新插入字符已在集合中,说明出现重复,此时移动 left 指针向右收缩窗口,同时从集合中移除窗口左侧字符,直到窗口内无重复字符。
  4. 在每次移动指针后,更新无重复字符的最长子串长度。
  5. 重复步骤 2 - 4,直到 right 指针到达字符串末尾。
🙋这个解题思路是怎么来的呢?

 我们首先最容易想到解法一:暴力求解

👇现在我们来分析以下字符串:

left=right=0,创建哈希表

如果right不在hash里面,将right的值存在hash里面,right++

 

当right所指的值已经在哈希表里了,我们计算len=right-left

接着我们让 left 走到与 right 所指的值的后面 ,即a的后面

重复以上过程,找到最大的len,直到right<n 

代码实现(以 C++ 为例):
class Solution {
public:
    // 函数用于计算给定字符串s中的最长无重复字符子串的长度
    int lengthOfLongestSubstring(string s) {
        // 创建一个大小为128的数组,用于记录每个字符出现的次数,初始化为0
        // 假设字符串中的字符ASCII码值范围在0 - 127之间
        int hash[127 + 1] = {0}; 

        int left = 0; // 滑动窗口的左边界指针,初始化为0
        int right = 0; // 滑动窗口的右边界指针,初始化为0
        int ret = 0; // 用于记录最长无重复字符子串的长度,初始化为0

        int n = s.size(); // 获取字符串s的长度

        // 开始移动右边界指针right来扩展滑动窗口
        while (right < n) {
            // 将右边界指针right指向的字符在hash数组中的计数加1
            hash[s[right]]++;

            // 当右边界指针right指向的字符出现次数大于1时,即出现重复字符
            while (hash[s[right]] > 1) {
                // 将左边界指针left指向的字符在hash数组中的计数减1,并将左边界指针left向右移动一位
                hash[s[left++]]--;
            }

            // 更新最长无重复字符子串的长度ret,取当前窗口长度(right - left + 1)与之前记录的ret中的较大值
            ret = std::max(ret, right - left + 1);

            right++; // 右边界指针right向右移动一位,继续扩展窗口
        }

        return ret; // 返回最长无重复字符子串的长度
    }
};
👀复杂度分析:
  • 时间复杂度:外层循环遍历字符串,内层循环虽可能多次执行但左、右边界指针总共移动次数最多为 2n 次,整体时间复杂度为O(n) ,n 是字符串长度。
  • 空间复杂度:仅用了固定大小的数组 hash 及几个固定占用空间的变量,空间复杂度为O(1) 。

💯总结

✍通过对这两道题目的深入剖析,我们深切体会到滑动窗口算法在处理数组和字符串问题时的高效性与灵活性。它通过巧妙维护窗口状态,避免了冗余计算,快速定位目标子结构。希望大家在后续算法学习中熟练掌握此算法,轻松应对类似挑战。


我将持续在算法领域深耕细作,为大家带来更多精彩的算法知识讲解与问题解析。欢迎大家关注我

👉【A Charmer】

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL数据库的备份与还原

目录 mysql 数据库的备份 生成SQL脚本 1 在控制台使用mysqldump命令可以用来生成指定数据库的脚本 ​编辑2 在数据库图形化界面工具&#xff1a;DateGrip 中操作&#xff1a;导出 mysql 数据库的还原 执行SQL脚本 1 在控制台使用 命令&#xff0c;指定将sql脚本导入到指定…

使用 IDEA 创建 Java 项目(二)

IDEA 创建 Java 项目 一般创建 Java 项目可以创建一个空项目&#xff0c;然后在空项目中添加模块&#xff0c;在模块中编写包&#xff0c;包中包含 Java 类。 如果你的 JDK 没有被 IDEA 自动找到的话&#xff0c;可以手动选择 JDK。我们先来学习 Intellij 构建系统下的 Java …

图论算法:最短路径算法详解【c语言版】(无权最短路径、Dijkstra算法)

别忘了请点个赞收藏关注支持一下博主喵&#xff01;&#xff01;&#xff01; 图论算法&#xff1a;最短路径算法详解 在图论中&#xff0c;最短路径问题是寻找图中两点之间具有最小总权重的路径。这个问题在许多实际应用中都有重要的作用&#xff0c;比如网络路由、城市交通规…

vue通过iframe方式嵌套grafana图表

文章目录 前言一、iframe方式实现xxx.xxx.com拒绝连接登录不跳转Cookie 的SameSite问题解决不显示额外区域(kiosk1) 前言 我们的前端是vue实现的&#xff0c;监控图表是在grafana中的&#xff0c;需要在项目web页面直接显示grafana图表 一、iframe方式实现 xxx.xxx.com拒绝连…

苹果系统安装Homebrew时CLT缺失的问题

前言 为了使用brew命令&#xff0c;必须安装Homebrew工具。但是在Howebrew安装的时候&#xff0c;会出现CLT&#xff08;Command Line Tools&#xff09;缺失的问题。本博客就是讨论如何来解决这个问题的。 1、问题的出现 2、解决途径 在命令行终端中输入命令&#xff1a;xcod…

LeetCode Hot100 49.字母异位词分组

题干&#xff1a; 思路&#xff1a; 输入的是一个字符串数组&#xff0c;输出是一个列表&#xff0c;首先我们需要通过遍历数组获得每一个字符串&#xff0c;我们想要判断获得的任意两个字符串是不是字母异位词&#xff0c;所以可以将获得的字符串排序&#xff08;转换为字符数…

小白初入Android_studio所遇到的坑以及怎么解决

1. 安装Android_studio 参考&#xff1a;Android Studio 安装配置教程 - Windows(详细版)-CSDN博客 Android Studio超级详细讲解下载、安装配置教程&#xff08;建议收藏&#xff09;_androidstudio-CSDN博客 想下旧版本的android_studio的地址&#xff08;仅供参考&#xf…

游戏引擎中LOD渲染技术

一.LOD(Level Of Detail) 为了降低GPU渲染压力,根据摄像机距离模型距离将面数较高的模型替换为面数较低的模型. LOD LOD0(distance<10) LOD1(distance<20) LOD2(distance<30) 故通常引擎中MetaMesh是由一个或多个LOD模型构成. MetaMesh mesh mesh.lod1 mesh.lod…

论文阅读《Structure-from-Motion Revisited》

摘要 增量式地运动结构恢复是从无序图像集合中进行三维重建的一个普遍策略。虽然增量式地重建系统在各个方面上都取得了巨大的进步&#xff0c;但鲁棒性、准确性、完整度和尺度仍然是构建真正通用管道的关键问题。我们提出了一种新的运动结构恢复技术&#xff0c;它改进了目前…

【人工智能训练师】3 集群搭建

开启集群环境 本次环境为单节点伪集群环境&#xff0c;环境中已经安装JDK1.8、Hadoop2.7.7、Mysql5.7、hive2.3.4。— 1.环境中已经安装/root/software/hadoop-2.7.7&#xff0c;格式化HDFS&#xff0c;开启集群&#xff0c;查看集群状态。&#xff08;HDFS端口为9000&#x…

使用 GPT-4V 全面评估泛化情绪识别 (GER)

概述 由于情绪在人机交互中扮演着重要角色&#xff0c;因此情绪识别备受研究人员关注。目前的情感识别研究主要集中在两个方面&#xff1a;一是识别刺激物引起的情感&#xff0c;并预测观众观看这些刺激物后的感受。另一个方面是分析图像和视频中的人类情绪。在本文中&#xf…

8.机器学习--决策树

(⊙﹏⊙)下周有要开组会&#xff0c;不知道该说啥&#xff0c;啊啊啊啊&#x1f62b; 目录 1.基本概念 2.ID3算法 3.C4.5算法 4.CART算法 5.连续与缺失值处理 5.1.连续值处理 5.2.缺失值处理 6.剪枝处理 6.1.预剪枝策略 6.2.后剪枝策略 7.实例代码 1.基本概念 提…

uniApp之uni-file-picker使用踩坑

标题党~也不算坑吧 就是初体验 上传是需要存储一下子的&#xff0c;我以为uniApp是自己免费开的服务给大家中转使用&#xff0c;就没管这个事&#xff0c;但是官网是这么说的&#xff1a; 就我是怎么发现的&#xff0c;使用了一段时间后&#xff0c;上传的图片都裂了&#xff…

22.04Ubuntu---ROS2使用rclcpp编写节点C++

节点需要存在于功能包当中&#xff0c;功能包需要存在于工作空间当中。 所以我们要想创建节点&#xff0c;就要先创建一个工作空间&#xff0c;再创建功能包。 第一步&#xff1a;创建工作空间 mkdir -p chapt2_ws/src/ 第二步&#xff1a;创建example_cpp功能包&#xff0c…

UIStackView使用进阶

01 技术背景 前端的布局方式比较灵活&#xff0c;提供有Flex的布局方式&#xff0c;可以实现不同方向的弹性布局。Flex就像一个容器&#xff0c;可以将其内部的子控件统一进行布局。其包含主轴方向和交叉轴方向&#xff0c;主轴方向表示控件的排布方向&#xff0c;交叉轴方向和…

AMD-OLMo:在 AMD Instinct MI250 GPU 上训练的新一代大型语言模型。

AMD-OLMo是一系列10亿参数语言模型&#xff0c;由AMD公司在AMD Instinct MI250 GPU上进行训练&#xff0c;AMD Instinct MI250 GPU是一个功能强大的图形处理器集群&#xff0c;它利用了OLMo这一公司开发的尖端语言模型。AMD 创建 OLMo 是为了突出其 Instinct GPU 在运行 “具有…

【HarmonyOS】Install Failed: error: failed to install bundle.code:9568289

【HarmonyOS】Install Failed: error: failed to install bundle.code:9568289 一、问题背景&#xff1a; Install Failed: error: failed to install bundle. code:9568289 error: install failed due to grant request permissions failed. View detailed instructions. 11/…

#渗透测试#SRC漏洞挖掘#CSRF漏洞的防御

免责声明 本教程仅为合法的教学目的而准备&#xff0c;严禁用于任何形式的违法犯罪活动及其他商业行为&#xff0c;在使用本教程前&#xff0c;您应确保该行为符合当地的法律法规&#xff0c;继续阅读即表示您需自行承担所有操作的后果&#xff0c;如有异议&#xff0c;请立即停…

C++builder中的人工智能(7)如何在C++中开发特别的AI激活函数?

在当今的AI开发中&#xff0c;人工智能模型正迅速增加。这些模型使用数学函数来执行和学习&#xff0c;以便在传播时优化最佳结果&#xff0c;或在反向传播时选择最佳解决方案。其中之一就是激活函数。也称为转移函数或阈值函数&#xff0c;它决定了神经元的激活值作为输出&…

ReactPress数据库表结构设计全面分析

ReactPress Github项目地址&#xff1a;https://github.com/fecommunity/reactpress 欢迎Star。 ReactPress是一个基于React框架开发的开源发布平台和内容管理系统&#xff08;CMS&#xff09;。它不仅支持用户在支持React和MySQL数据库的服务器上搭建自己的博客和网站&#…