滑动窗口算法 - LCR 014. 字符串的排列

前言

接前文 滑动窗口算法 - LC76 最小覆盖子串-CSDN博客,此题也是套用滑窗模板,但是在两个细节点处稍有不同。

正文

LCR 014. 字符串的排列

给定两个字符串 s1 和 s2,写一个函数来判断 s2 是否包含 s1 的某个变位词。

换句话说,第一个字符串的排列之一是第二个字符串的 子串 。

题解:

func checkInclusion(s2 string, s1 string) bool {window := make(map[byte]int)need := make(map[byte]int)for i := 0; i < len(s2); i++ {need[s2[i]]++}n := len(s1)l, r := 0, 0valid := 0for r < n {c := s1[r]r++if need[c] > 0 {window[c]++if need[c] == window[c] {valid++}}for r-l == len(s2) {if valid == len(need) {return true}d := s1[l]l++if need[d] > 0 {if need[d] == window[d] {valid--}window[d]--}}}return false
}

细节点:

(1)注意窗口收缩的条件发生改变,即左指针移动的条件发生改变,只要当前窗口的长度>=目标字符串的长度,即l-r >len(s2),注意不是l-r > len(need)那么就开始收缩,因为我们要找的覆盖子串是要和目标字符串长度相等的不同排列

(2)len(need)是目标字符串里不重复元素个数,len(s2)是目标字符串长度,当r-l == len(s2)并且valid==len(need)时,说明在s1中找到了s2的不同排列的字符串,所以可以直接return true。

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

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

相关文章

Linux多进程通信总结——进程间通信看这一篇足够啦!

1.进程间通信方式综合比较 优点缺点有名管道1&#xff09;任意进程间通信1&#xff09;缓冲区有限无名管道1&#xff09;简单方便1&#xff09;单向通信2&#xff09;父子进程间通信3&#xff09;缓冲区有限消息队列1&#xff09;任意进程通信2&#xff09;无需考虑进程间同步…

Linux 文件相关命令

一、查看文件命令 1&#xff09;浏览文件less 默认查看文件的前 10 行。 less /etc/services ##功能说明&#xff1a; #1.默认打开首屏内容 #2.按【回车】按行访问 #3.按【空格】按屏访问 #4.【从上向下】搜索用/111,搜索包含111的内容&#xff0c;此时按n继续向下搜&#x…

PCL 基于直线进行KMeans聚类

文章目录 一、K-Means算法二、K-Means算法步骤三、实现代码四、实现效果参考文献一、K-Means算法 在诸多的聚类方法中,K-Means聚类方法是属于“基于原型的聚类”(也称为原型聚类)的方法,此类方法均是假设聚类结构能通过一组原型刻画,在现实聚类中极为常用。通常情况下,该类…

JAVAEE之IoCDI

Spring 是⼀个 IoC&#xff08;控制反转&#xff09;容器&#xff0c;作为容器, 那么它就具备两个最基础的功能&#xff1a; • 存 • 取 Spring 容器管理的主要是对象, 这些对象, 我们称之为"Bean". 我们把这些对象交由Spring管理, 由 Spring来负责对象的创建…

想学网络安全,从哪里开始?网络安全的学习路线

网络安全学习路线&#xff1a; 想学习网络安全专业的知识&#xff0c;想当黑客&#xff0c;但是不知道该从哪里开始学。 我给你一个路线&#xff01; 清晰图片和大纲&#xff1a;https://docs.qq.com/doc/DU1lpVFpSbWVrd2p3

面试官:为什么忘记密码要重置,而不是告诉我原密码?

前端训练营&#xff1a;1v1私教&#xff0c;终身辅导计划&#xff0c;帮你拿到满意的 offer。 已帮助数百位同学拿到了中大厂 offer。欢迎来撩~~~~~~~~ Hello&#xff0c;大家好&#xff0c;我是 Sunday。 最近有个同学在面试中遇到了一个很有意思的问题&#xff0c;我相信大多…

基于单片机的电动车电池充电保护装置设计

摘 要:针对电动车充电安全方面的隐患,提出基于单片机控制的电动车电池充电保护装置的设 计。该装置以单片机为核心,包含数字温度传感器、控制按钮、外接显示屏、降温风扇及其他组件。控制按钮主要用来设定温度,温度传感器分别装在蓄电池和充电器内部,若充电器或蓄电池温度…

蓝桥杯23年第十四届省赛-异或和之和|拆位、贡献法

题目链接&#xff1a; 蓝桥杯2023年第十四届省赛真题-异或和之和 - C语言网 (dotcpp.com) 1.异或和之和 - 蓝桥云课 (lanqiao.cn) 参考题解&#xff1a; 蓝桥杯真题讲解&#xff1a;异或和之和 &#xff08;拆位、贡献法&#xff09;-CSDN博客 洛谷P9236 [蓝桥杯 2023 省 A]…

ubuntu23 安装minio

要在Ubuntu 23版本上安装MinIO&#xff0c;您可以遵循以下步骤&#xff1a; 1. 下载MinIO Server二进制文件 访问MinIO官方下载页面&#xff08;https://min.io/download&#xff09;&#xff0c;或者直接在终端使用wget命令下载最新版本的MinIO二进制文件。假设您想要安装的…

【T5中的激活函数】GLU Variants Improve Transformer

【mT5中的激活函数】GLU Variants Improve Transformer 论文信息 阅读评价 Abstract Introduction Gated Linear Units (GLU) and Variants Experiments on Text-to-Text Transfer Transformer (T5) Conclusion 论文信息 名称内容论文标题GLU Variants Improve Transfo…

Python课程设计(课设)源码哪里找?

在互联网上寻找免费的Python课程设计&#xff08;课设&#xff09;源码&#xff0c;可以参考以下几个途径&#xff1a; 开源平台&#xff1a;GitHub是一个非常受欢迎的开源代码托管平台&#xff0c;你可以在这里搜索相关的Python项目。很多开发者会将他们的项目开源&#xff0c…

flutter获取手机中的系统路径信息

https://www.bilibili.com/video/BV1wE421g7sw获取系统中的路径 获取系统中的路径&#xff0c;并在这个路径中创建一个文本文件【str.txt】 然后进行写入【str.txt】 再读取这个文件【str.txt】 手机没有开通root权限无法看到写入到【应用程序文档目录】路径中的文件 用来…

MySQL故障排查与优化

一、MySQL故障排查 1.1 故障现象与解决方法 1.1.1 故障1 1.1.2 故障2 1.1.3 故障3 1.1.4 故障4 1.1.5 故障5 1.1.6 故障6 1.1.7 故障7​ 1.1.8 故障8 1.1.9 MySQL 主从故障排查 二、MySQL优化 2.1 硬件方面 2.2 查询优化 一、MySQL故障排查 1.1 故障现象与解决方…

【考研经验贴】24考研860软件工程佛系上岸经验分享【丰富简历、初复试攻略、导师志愿、资料汇总】

&#x1f60a;你好&#xff0c;我是小航&#xff0c;一个正在变秃、变强的文艺倾年。 &#x1f514;本文讲解24考研860软件工程佛系上岸经验分享【丰富简历、初复试攻略、导师志愿、资料汇总】&#xff0c;期待与你一同探索、学习、进步&#xff0c;一起卷起来叭&#xff01; 目…

Hot100-80(Leetcode763划分字母区间)

代码&#xff1a; class Solution {public List<Integer> partitionLabels(String s) {int n s.length();boolean f[] new boolean[n1];Map<Character,Integer> map new HashMap<>();for(int i0;i<n;i){if(!map.containsKey(s.charAt(i))){f[i]true;m…

玩转C语言——文件操作、预处理、编译、链接

前言&#xff1a; 经过前面的学习&#xff0c;我们已经对C语言的语法学习完毕了&#xff0c;今天&#xff0c;我们这节内容是为了修炼内功&#xff0c;为以后的学习打下一个坚实基础。话不多说&#xff0c;开始我们今天的学习吧&#xff01; 一、文件操作 1.⼆进制⽂件和⽂本⽂…

一文了解低功耗蓝牙BLE

低功耗蓝牙技术可以构建两种类型的设备:双模设备和单模设备。双模设备既支持经典蓝牙又支持低功耗蓝牙。单模设备只支持低功耗蓝牙。还有仅支持经典蓝牙的设备。 在链路层,设备被分为广播者、扫描者、从设备和主设备。广播者是传输数据包的设备,扫描者是接收广播者的数据包…

其他元素

img元素 在文档中显示图像&#xff0c;可以任意改变图像的大小和外观 属性值 src属性&#xff1a;指定图像的路径 alt属性&#xff1a;提供备用文本&#xff08;当网络延迟或src出错时显示&#xff09; <img src"../../picture/屏幕截图 2024-03-08 231030.png&quo…

C语言 | Leetcode C语言题解之第10题正则表达式匹配

题目&#xff1a; 题解&#xff1a; bool isMatch(char* s, char* p) {int m strlen(s);int n strlen(p);// dp[i][j] 表示 s 的前 i 个字符和 p 的前 j 个字符是否匹配bool dp[m 1][n 1];memset(dp, false, sizeof(dp));dp[0][0] true; // 空字符串和空模式匹配// 处理 …

00-JAVA基础-javassist字节码操作

字节码操作 什么是字节码 Java字节码&#xff08;Java bytecode&#xff09;是Java虚拟机&#xff08;JVM&#xff09;执行的一种虚拟指令格式。它是由Java编译器生成的&#xff0c;基于栈的指令集&#xff0c;用于在Java虚拟机上执行。字节码文件包含了JVM能够识别的指令&am…