【C++速刷精品】滑动窗口

2023-12-19 03:36
文章标签 c++ 窗口 滑动 精品 速刷

本文主要是介绍【C++速刷精品】滑动窗口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【C++速刷精品】滑动窗口

  • 一、长度最小的子数组
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 二、无重复字符的最长字串
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 三、最大连续1的个数III
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 四、将x减到0的最小操作数
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 五、水果成篮
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 六、找到字符串中所有字母异位词
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 七、串联所有单词的字串
    • 1、题目链接
    • 2、题目解析
    • 3、代码
  • 八、最小覆盖字串
    • 1、题目链接
    • 2、题目解析
    • 3、代码


一、长度最小的子数组

1、题目链接

leetcode链接

在这里插入图片描述

2、题目解析

讲解一下什么是滑动窗口?
滑动窗口就是一个同向双指针利用单调性的两个指针区间为窗口,right指针往右移动则是入窗口,left指针往右移动则是出窗口,我们用的步骤如下图:
在这里插入图片描述
在这里插入图片描述

3、代码

在这里插入图片描述

二、无重复字符的最长字串

1、题目链接

leetcode链接
在这里插入图片描述

2、题目解析

构造一个hash函数表,将right和left从0开始,不断的将right的值存入到hash表中,如果发现表中存入了两个了,那么就更新left的值,并进行更新ret。

在这里插入图片描述

3、代码

在这里插入图片描述

三、最大连续1的个数III

1、题目链接

题目链接

在这里插入图片描述

2、题目解析

此时定义一个ret用来记录走过的0的个数,right走过一个0就加加,left走过一个0就减减,我们循环的条件在于:当right指针遇见1的时候,一直往右走直到遇见0,每遇见一个0就将ret进行加加,直到ret的个数比k大的时候就需要出窗口了,也就是我们的left指针往右移动,直到找到0,每遇见一个0就将ret减减再left往右走一步,这个判断跳出条件在于ret<k,而在每次进行这个操作的时候,我们都进行算一下下标,也就是中间有多少个元素,最终等right到最后一个位置的下一个位置的时候,我们就结束。

在这里插入图片描述

3、代码

在这里插入图片描述

四、将x减到0的最小操作数

1、题目链接

leetcode链接

在这里插入图片描述

2、题目解析

在这里插入图片描述

在这里插入图片描述

3、代码

在这里插入图片描述

五、水果成篮

1、题目链接

leetcode链接

在这里插入图片描述

2、题目解析

在这里插入图片描述

3、代码

在这里插入图片描述

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

1、题目链接

leetcode链接
在这里插入图片描述

2、题目解析

在这里插入图片描述

3、代码

在这里插入图片描述

七、串联所有单词的字串

1、题目链接

leetcode传送门

在这里插入图片描述

2、题目解析

在这里插入图片描述
在这里插入图片描述

3、代码

在这里插入图片描述

八、最小覆盖字串

1、题目链接

leetcode链接

在这里插入图片描述

2、题目解析

在这里插入图片描述

在这里插入图片描述

3、代码

NO1.利用unordered_map容器来进行解决,但算法复杂度太高
在这里插入图片描述

No2.用hash数组进行解决,算法复杂度低
在这里插入图片描述


这篇关于【C++速刷精品】滑动窗口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510764

相关文章

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

bat脚本启动git bash窗口,并执行命令方式

《bat脚本启动gitbash窗口,并执行命令方式》本文介绍了如何在Windows服务器上使用cmd启动jar包时出现乱码的问题,并提供了解决方法——使用GitBash窗口启动并设置编码,通过编写s... 目录一、简介二、使用说明2.1 start.BAT脚本2.2 参数说明2.3 效果总结一、简介某些情

基于Redis有序集合实现滑动窗口限流的步骤

《基于Redis有序集合实现滑动窗口限流的步骤》滑动窗口算法是一种基于时间窗口的限流算法,通过动态地滑动窗口,可以动态调整限流的速率,Redis有序集合可以用来实现滑动窗口限流,本文介绍基于Redis... 滑动窗口算法是一种基于时间窗口的限流算法,它将时间划分为若干个固定大小的窗口,每个窗口内记录了该时间

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名