news 2026/2/3 4:13:23

LeetCode热题100:438. 找到字符串中所有字母异位词

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode热题100:438. 找到字符串中所有字母异位词

简介

题目链接:https://leetcode.cn/problems/find-all-anagrams-in-a-string/?envType=problem-list-v2&envId=2cktkvj

解决方式:滑动窗口

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

滑动窗口

classSolution{// 滑动窗口// 大体思路是有两个数组,一个代表滑动窗口,一个代表目标字符串,滑动窗口的大小于与目标字符串相同// 移动滑动窗口,比较两数组是否相同。相同则表示寻找到目标的字母异位体,因为两者的字符、数量相同publicList<Integer>findAnagrams(Strings,Stringp){intsLen=s.length(),pLen=p.length();// 特例判断if(sLen<pLen){returnnewArrayList<Integer>();}// 初始化数组和结果集ArrayList<Integer>ans=newArrayList<>();int[]sCount=newint[26];int[]pCount=newint[26];// 初始化滑动窗口for(inti=0;i<pLen;i++){// 字符与数组索引映射++sCount[s.charAt(i)-'a'];++pCount[p.charAt(i)-'a'];}if(Arrays.equals(sCount,pCount)){ans.add(0);}// 移动滑动窗口// 此时,i 代表滑动窗口的左边界以及 s 中剩下的字符,即滑动窗口需要移动的次数for(inti=0;i<sLen-pLen;i++){// 去除左边界元素--sCount[s.charAt(i)-'a'];// 滑动窗口向右移动++sCount[s.charAt(i+pLen)-'a'];// 判断if(Arrays.equals(sCount,pCount)){// 初始位置为左边界 + 1ans.add(i+1);}}returnans;}}

滑动窗口优化

classSolution{// 滑动窗口优化// 大体思路是维护一个数组和一个不同变量 differ,取代两个数组的全量比较publicList<Integer>findAnagrams(Strings,Stringp){intsLen=s.length(),pLen=p.length();// 特例判断if(sLen<pLen){returnnewArrayList<Integer>();}// 初始化数组和结果集ArrayList<Integer>ans=newArrayList<>();int[]count=newint[26];// 初始化滑动窗口for(inti=0;i<pLen;i++){// 字符与数组索引映射++count[s.charAt(i)-'a'];--count[p.charAt(i)-'a'];}// 记录当前窗口与目标字符种类不同的个数,检验是否找到字母异位体// 相同字符不同个数不重复计入intdiffer=0;for(intj=0;j<26;++j){if(count[j]!=0){++differ;}}if(differ==0){ans.add(0);}// 移动滑动窗口// 此时,i 代表滑动窗口的左边界以及 s 中剩下的字符,即滑动窗口需要移动的次数// 检验是否异位体,是通过判断 differ 是否为 0for(inti=0;i<sLen-pLen;i++){// 移动左边界// 左边界的变动会导致滑动窗口的字符发生变化// 需要判断会不会导致 differ 变化,即窗口找到异位体if(count[s.charAt(i)-'a']==1){--differ;}elseif(count[s.charAt(i)-'a']==0){++differ;}--count[s.charAt(i)-'a'];// 真正移动// 移动右边界// 右边界的变动也会导致滑动窗口的字符发生变化// 也需要判断会不会导致 differ 变化,即窗口找到异位体if(count[s.charAt(i+pLen)-'a']==-1){--differ;}elseif(count[s.charAt(i+pLen)-'a']==0){++differ;}++count[s.charAt(i+pLen)-'a'];// 真正移动// 判断if(differ==0){ans.add(i+1);}}returnans;}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 2:18:41

【稀缺资源曝光】MCP量子编程认证内部培训资料首次全公开

第一章&#xff1a;MCP量子编程认证概述MCP量子编程认证&#xff08;Microsoft Certified Professional Quantum Programming Certification&#xff09;是微软为开发者提供的专业级量子计算技能认证体系&#xff0c;旨在验证开发者在Q#语言、量子算法设计与Azure Quantum平台应…

作者头像 李华
网站建设 2026/1/23 5:12:47

远程开发效率翻倍,VSCode文件同步配置你真的掌握了吗?

第一章&#xff1a;远程开发效率翻倍&#xff0c;VSCode文件同步配置你真的掌握了吗&#xff1f;在现代软件开发中&#xff0c;远程开发已成为常态。VSCode 通过 Remote - SSH、Remote - Containers 等扩展&#xff0c;极大提升了开发者在远程服务器或容器中工作的效率。而文件…

作者头像 李华
网站建设 2026/2/2 20:37:27

后端成本砍掉 90% 后,我发现 Render 和 Railway 都做错了一件事

2025年&#xff0c;Serverless PaaS 平台三国杀&#xff1a;Sealos、Render、Railway 横评如今&#xff0c;开发者们正从复杂的云服务&#xff0c;转向 Render、Railway 和 Sealos 这类新一代 PaaS 平台。它们都承诺让开发回归简单&#xff0c;但体验和成本却差异巨大。我用一个…

作者头像 李华
网站建设 2026/1/23 19:19:50

SynthDoG技术解析:如何解决文档理解模型的数据瓶颈问题

SynthDoG技术解析&#xff1a;如何解决文档理解模型的数据瓶颈问题 【免费下载链接】donut Official Implementation of OCR-free Document Understanding Transformer (Donut) and Synthetic Document Generator (SynthDoG), ECCV 2022 项目地址: https://gitcode.com/gh_mi…

作者头像 李华
网站建设 2026/1/30 17:53:24

Open Library 深度探索:构建你的专属数字图书馆王国

想象一下&#xff0c;在你的指尖轻轻一点之间&#xff0c;就能拥有一个包含数百万本图书的私人图书馆。这不是科幻电影中的场景&#xff0c;而是 Open Library 为你带来的真实体验。这个革命性的开源项目正在重新定义数字阅读的未来。 【免费下载链接】openlibrary One webpage…

作者头像 李华
网站建设 2026/1/27 11:38:12

MapGIS DataStore产品安装要求

MapGIS DataStore产品安装要求 一、介绍 ​ MapGIS DataStore是一个以分布式方式存储和管理关系型数据、切片型数据、实时型数据以及非结构数据的混合数据库&#xff0c;与MapGIS SDE无缝融合&#xff0c;形成完整的地理大数据存储管理方案。二、产品安装要求 Windows操作系统…

作者头像 李华