算法2:滑动窗口(下)

文章目录

  • 水果成篮
  • 找到字符串中所有字母异位词
  • 串联所有单词的子串*
  • 最小覆盖子串*

水果成篮

在这里插入图片描述
两元素排空操作
窗口中存在元素交错情况,所以出窗口一定要出干净!!!

class Solution {
public:int totalFruit(vector<int>& fruits) {unordered_map<int, int> hash; // 统计水果情况int res = 0;for (int left = 0, right = 0; right < fruits.size(); right++) {hash[fruits[right]]++;  // 进窗口while (hash.size() > 2) // 判断{// 出窗口hash[fruits[left]]--;if (hash[fruits[left]] == 0)hash.erase(fruits[left]);left++;}res = max(right - left + 1, res);}return res;}
};

优化:

class Solution {
public:int totalFruit(vector<int>& fruits) {int hash[100001] = {0}; // 统计水果情况int res = 0;for (int left = 0, right = 0, kinds = 0; right < fruits.size();right++) {if (hash[fruits[right]] == 0)kinds++;           // 维护水果种类hash[fruits[right]]++; // 进窗口while (kinds > 2)      // 判断{// 出窗口hash[fruits[left]]--;if (hash[fruits[left]] == 0)kinds--;left++;}res = max(right - left + 1, res);}return res;}
};

技巧:数据有限的情况下,用数组比用容器快很多

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

在这里插入图片描述

class Solution {
public:vector<int> findAnagrams(string s, string p) {if (s.size() < p.size())return {};vector<int> res;long long sum = 0;for (auto e : p)sum += (e - '0') * (e - '0') * (e - '0');int left = 0, right = 0;long long target = 0;while (right < s.size()) {target += (s[right] - '0') * (s[right] - '0') * (s[right] - '0');while (target >= sum && left <= right) {if (target == sum && right - left == p.size() - 1)res.push_back(left);target -= (s[left] - '0') * (s[left] - '0') * (s[left] - '0');left++;}right++;}return res;}
};
class Solution {
public:vector<int> findAnagrams(string s, string p) {if (s.size() < p.size())return {};int hash1[26] = {0};for (auto e : p)hash1[e - 'a']++;vector<int> res;int hash2[26] = {0};int m = p.size();for (int left = 0, right = 0, count = 0; right < s.size(); right++) {char in = s[right];if (++hash2[in - 'a'] <= hash1[in - 'a']) // 进窗口及维护countcount++;if (right - left + 1 > m) // 判断{char out = s[left++];if (hash2[out - 'a']-- <= hash1[out - 'a'])count--; // 出窗口及维护count}// 结果更新if (count == m)res.push_back(left);}return res;}
};

串联所有单词的子串*

在这里插入图片描述

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

class Solution {
public:vector<int> findSubstring(string s, vector<string>& words) {int slen = s.size(), plen = words.size(), _size = words[0].size();plen *= _size;if (plen == 0 || slen < plen)return {};// 滑动窗口+哈希表vector<int> res;unordered_map<string, int> aCount;for (auto& e : words)aCount[e]++;unordered_map<string, int> bCount;int n = words[0].size();while (n--) /// 执行n次滑动窗口{for (int left = n, right = n, count = 0; right + _size <= s.size();right += words[0].size()) {string in = s.substr(right, words[0].size());bCount[in]++;// if(aCount[in] && bCount[in] <= aCount[in])   count++;if (aCount.count(in) && bCount[in] <= aCount[in])count++;// 这里窗口的长度是right + len -left,// 也就是说窗口的长度已经大于words的总体长度if (right - left == words[0].size() * words.size()) {string out = s.substr(left, words[0].size());// 这里用[]会影响速度,用哈希的计数函数快一些// count函数的返回值是0或1// ,类似于bool值,表示其是否存在,而[]返回的是次数,就涉及到了查找,故花费时间较长if (aCount.count(out) && bCount[out] <= aCount[out])count--;// if(aCount[out] && bCount[out] <= aCount[out]) count--;bCount[out]--;left += words[0].size();}if (count == words.size())res.push_back(left);}bCount.clear();}return res;}
};```cpp
class Solution {
public:vector<int> findSubstring(string s, vector<string>& words) {vector<int> result;if (s.empty() || words.empty())return result;int word_length = words[0].length();int num_words = words.size();int total_length = word_length * num_words;unordered_map<string, int> word_count;for (const string& word : words) {word_count[word]++;}for (int i = 0; i < word_length; ++i) {int left = i, right = i;unordered_map<string, int> window_count;while (right + word_length <= s.length()) {string word = s.substr(right, word_length);right += word_length;if (word_count.find(word) != word_count.end()) {window_count[word]++;while (window_count[word] > word_count[word]) {string left_word = s.substr(left, word_length);window_count[left_word]--;left += word_length;}if (right - left == total_length) {result.push_back(left);}} else {window_count.clear();left = right;}}}return result;}
};

两段代码都是:哈希+滑动窗口,时间空间复杂度也一样,但是测试时间却减少了许多,可以对比一下第二段代码优于第一段代码的点在哪里?

最小覆盖子串*

在这里插入图片描述

在这里插入图片描述

class Solution {
public:string minWindow(string s, string t) {string res;int hash[128] = {0};int tt = 0; // 字符种类for (char& e : t)if (0 == hash[e]++)tt++;int hash1[128] = {0};int begin = -1, m = INT_MAX;for (int left = 0, right = 0, count = 0; right < s.size(); right++) {// 进窗口char in = s[right];if (++hash1[in] == hash[in])count++;//  检查while (count == tt) {//  更新if (right - left + 1 < m) {begin = left;m = right - left + 1;}//  出窗口char out = s[left++];if (hash1[out]-- == hash[out])count--;}}if (begin != -1)res = s.substr(begin, m);return res;}
};
//  "ADOBEC"

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

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

相关文章

行心科技中禄松波携手,开启智能健康新时代

在2024年第34届健博会暨中国大健康产业文化节的盛大舞台上&#xff0c;广州市行心信息科技有限公司&#xff08;以下简称“行心科技”&#xff09;与浙江中禄松波生物工程有限公司&#xff08;以下简称“中禄松波”&#xff09;宣布达成战略合作&#xff0c;共同推动医康养产业…

[职场] 美术指导的重要作用 #学习方法#笔记

美术指导的重要作用 美术指导是广告、电影、电视剧等创意作品中的一个重要角色&#xff0c;负责整体视觉风格和美术设计的指导和管理。 美术指导的目标是通过视觉表达来传达故事的情感、氛围和主题&#xff0c;以及塑造角色和场景的形象。 美术指导在创作过程中扮演着重要的角…

Linux网络的DHCP配置

文章目录 DHCP配置DHCP流程简述DHCP优点DHCP的分配方式DHCP的租约过程DHCP配置实验实验1实验2 DHCP配置 DHCP&#xff1a;动态主机配置协议 服务端和客户端 服务端&#xff1a;server&#xff0c;提供某种特定的服务 客户端&#xff1a;client&#xff0c;使用服务端提供的服…

人体感应提醒 大声公+微波模块

文章目录 模块简介接线程序示例 模块简介 微波感应开关模块 RCWL-0516是一款采用多普勒雷达技术&#xff0c;专门检测物体移动的微波感应模块。采用 2.7G 微波信号检测&#xff0c;该模块具有灵敏度高&#xff0c;感应距离远&#xff0c;可靠性强&#xff0c;感应角度大&#…

Ruoyi-Vue-Plus 下载启动后菜单无法点击展开,

1.Ruoyi-Vue-Plus框架下载后运行 2.使用mock数据 3.进入页面后无法点击菜单 本以为是动态路由或者菜单逻辑出了问题&#xff0c;最后发现是websocket的问题 解决办法 把这两行代码注释 页面菜单即可点击。 以上。

【ROS使用记录】—— ros使用过程中的rosbag录制播放和ros话题信息相关的指令与操作记录

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、rosbag的介绍二、rosbag的在线和离线录制三、rosbag的播放相关的指令四、其他rosbag和ros话题相关的指令总结 前言 rosbag是ROS&#xff08;机器人操作系统…

Suse Linux ssh配置免密后仍需要输入密码

【问题描述】 Suse Linux已经配置了ssh免密&#xff0c;但无法ssh到目标服务器。 对自身的ssh登陆也需要输入密码。 系统–Suse 15 SP5 【重现步骤】 1.使用ssh-keygen -t rsa生产key文件 2.使用ssh-copy-id拷贝public key到目标机器(或者自身) 3.配置成功后ssh 目标时仍需要输…

[C#]使用OpenCvSharp图像滤波中值滤波均值滤波高通滤波双边滤波锐化滤波自定义滤波

在使用OpenCvSharp进行图像滤波处理时&#xff0c;各种滤波方法都有其特定的用途和效果。以下是对中值滤波、均值滤波、高通滤波、双边滤波、锐化滤波和自定义滤波的详细解释和归纳&#xff1a; 中值滤波&#xff08;MedianBlur&#xff09; 原理与作用&#xff1a;中值滤波是…

Stable diffusion采样器详解

在我们使用SD web UI的过程中&#xff0c;有很多采样器可以选择&#xff0c;那么什么是采样器&#xff1f;它们是如何工作的&#xff1f;它们之间有什么区别&#xff1f;你应该使用哪一个&#xff1f;这篇文章将会给你想要的答案。 什么是采样&#xff1f; Stable Diffusion模…

UI学习--导航控制器

导航控制器 导航控制器基础基本概念具体使用 导航控制器切换演示具体使用注意 导航栏与工具栏基本概念具体使用&#xff1a; 总结 导航控制器基础 基本概念 根视图控制器&#xff08;Root View Controller&#xff09;&#xff1a;导航控制器的第一个视图控制器&#xff0c;通…

压缩大文件消耗电脑CPU资源达到33%以上

今天用7-Zip压缩一个大文件&#xff0c;文件大小是9G多&#xff0c;这时能听到电脑风扇声音&#xff0c;查看了一下电脑资源使用情况&#xff0c;确实增加了不少。 下面是两张图片&#xff0c;图片上有电脑资源使用数据。

Spring系统学习 -Spring IOC 的XML管理Bean之bean的获取、依赖注入值的方式

在Spring框架中&#xff0c;XML配置是最传统和最常见的方式之一&#xff0c;用于管理Bean的创建、依赖注入和生命周期等。这个在Spring中我们使用算是常用的&#xff0c;我们需要根据Spring的基于XML管理Bean了解相关Spring中常用的获取bean的方式、依赖注入值的几种方式等等。…

Maven项目打包成jar项目后运行报错误: 找不到或无法加载主类 Main.Main 和 jar中没有主清单属性解决方案

已经用maven工程的package功能进行了打包 找不到或无法加载主类 Main.Main 规定主类 主要在maven的配置文件当中 这边一定要绑定自己的启动类 jar中没有主清单属性 删掉这一行就行哈 正确的插件代码 <plugin><groupId>org.springframework.boot</groupId&…

毫米波SDK使用1

本文档是AM273x等毫米波雷达处理器SDK的配置和使用&#xff0c;主要参考TI的官方文档《mmwave mcuplus sdk user guide》。这里仅摘取其中重要的部分&#xff0c;其余枝节可参考原文。 2 系统概览 mmWave SDK分为两个主要组件:mmWave套件和mmWave演示。 2.1. mmWave套件 mmWa…

AXI Quad SPI IP核基于AXI-Lite接口的标准SPI设计指南

在标准SPI配置下&#xff0c;SPI设备除了包含基本的SPI特性外&#xff0c;还具备以下一些标准功能&#xff0c;这些功能如下所示&#xff1a; 支持FPGA内部的多主设备配置&#xff0c;其中使用单独的_I&#xff08;输入&#xff09;、_O&#xff08;输出&#xff09;、_T&…

FM148A,FM146B运行备件

FM148A,FM146B运行备件。电源保险丝仓主控底座的保险丝仓示意图底座上共有两个保险丝&#xff08;800mA&#xff09;&#xff0c;FM148A,FM146B运行备件。&#xff08;10&#xff5e;73&#xff09;30/195主控单元2.K-CUT014槽底座地址接口主控站地址拨开关从上到下为二进制数的…

开发网站,如何给上传图片的服务器目录授权

开发网站&#xff0c;上传图像时提示”上传图片失败&#xff0c;Impossible to create the root directory /var/www/html/xxxxx/public/uploads/avatar/20240608.“ 在Ubuntu上&#xff0c;你可以通过调整文件夹权限来解决这个问题。首先&#xff0c;确保Web服务器&#xff08…

【笔记】从零开始做一个精灵龙女-装备阶段

这里只记录相对重要的步骤和一些思路 但是头发那块很详细哦~ &#xff08;标的小数字不用在意&#xff0c;那个是我网课的时长记录&#xff09; 耳环 1.创建一个圆环&#xff0c;调整参数 做好后再复制一个小的 肩甲 2.0-2.4 1.创建圆柱体/球体也可 然后把底部的两个点删…

Xsens动作捕捉系统:角色动画制作与运动分析领域的先进工具

随着传感器技术的不断进步&#xff0c;动作捕捉技术现在更加趋向于民用化&#xff0c;拥有价格优势的惯性动作捕捉系统现在更多的出现在独立动画工作室与国内外多所高校的实际项目应用中。 凭借无场地限制、价格优惠、校准使用方便、数据采集精确等多项优势&#xff0c;Xsens惯…

[AI Google] 双子座模型家族迎来新突破:更快的模型、更长的上下文、AI代理等更多功能

Google发布了Gemini模型家族的更新&#xff0c;包括新的1.5 Flash模型&#xff0c;该模型旨在提高速度和效率&#xff0c;以及Project Astra&#xff0c;这是对未来AI助手愿景的展示。1.5 Flash是专为大规模高频任务优化的轻量级模型&#xff0c;具有突破性的长上下文窗口。同时…