当前位置: 首页 > ops >正文

LeetCode hot100-9

题目描述

题目链接:找到字符串中所有字母异位词

给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。

示例 1:

输入: s = "cbaebabacd", p = "abc"

输出: [0,6]

解释: 起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。 起始索引等于 6 的子串是 "bac", 它是 "abc" 的异位词。

 示例 2:

输入: s = "abab", p = "ab"

输出: [0,1,2]

解释: 起始索引等于 0 的子串是 "ab", 它是 "ab" 的异位词。 起始索引等于 1 的子串是 "ba", 它是 "ab" 的异位词。 起始索引等于 2 的子串是 "ab", 它是 "ab" 的异位词。

提示:

  • 1 <= s.length, p.length <= 3 * 104
  • s 和 p 仅包含小写字母

思路解析

判断异位词思路:因为字符串中只有小写字母,所以利用一个大小为26的数组进行统计每一个字母的数量,当每个字母数量相同时则为异位词。

滑动窗口进行遍历每一个长度跟p相同的字串:左端点记录字串开始位置,是异位词时向答案数组中添加下标,右端点记录字串最后一个元素下一个元素的位置,滑动窗口向后移的时候该位置元素计数+1,左端点位置元素计数-1。

注意:不管先判断异位词还是先滑动窗口,不要漏掉判断第一个和最后一个字串。

代码实现

class Solution {
public:vector<int> findAnagrams(string s, string p) {if(s.size()<p.size())return {};//如果s长度小于p则不可能有子串为p的异位词vector<int>vec;//答案数组int n=p.size();int cnt[26];//计数数组for(int i=0;i<n;i++){//初始化cnt[p[i]-'a']++;cnt[s[i]-'a']--;}for(int l=0,r=n;r<=s.size();l++,r++){//滑动窗口更新计数数组判断是否为异位词int k=1;for(auto it:cnt)//遍历计数数组,全为0时表示为异位词if(it!=0){k=0;break;}if(k)vec.push_back(l);if(r==s.size())break;cnt[s[l]-'a']++;cnt[s[r]-'a']--;}return vec;}
};

http://www.xdnf.cn/news/10255.html

相关文章:

  • 让大模型看得见自己的推理 — KnowTrace结构化知识追踪
  • 时间的基本概念与相关技术三
  • 【六. Java面向对象编程入门指南】
  • HackMyVM-Ephemeral3
  • js数据类型有哪些?它们有什么区别?
  • 吴恩达MCP课程(3):mcp_chatbot
  • NW994NX734美光固态闪存NX737NX740
  • SpringBoot如何实现一个自定义Starter?
  • python创建args命令行分析
  • Halcon
  • 从gitee仓库中恢复IDEA项目某一版本
  • Java基础 Day26
  • NumPy 数组计算:广播机制
  • langchain学习 01
  • enumiax:IAX 协议用户名枚举器!全参数详细教程!Kali Linux教程!
  • Vue 核心技术与实战day06
  • Java并发编程实战 Day 2:线程安全与synchronized关键字
  • JS逆向案例—喜马拉雅xm-sign详情页爬取
  • 【xmb】内部文档148344597
  • HomeKit 基本理解
  • JavaSwing之--为组件添加背景
  • 记忆胶囊应用源码纯开源
  • Linux命令之ausearch命令
  • TDengine 集群运行监控
  • Java中的ConcurrentHashMap的使用与原理
  • C语言 — 动态内存管理
  • 杨辉三角系数
  • 嵌入式学习笔记 - STM32 HAL库以及标准库内核以及外设头文件区别问题
  • 【android bluetooth 协议分析 03】【蓝牙扫描详解 1】【扫描关键函数 btif_dm_search_devices_evt 分析】
  • proteus新建工程