LeetCode hoot 100 -- 找到字符串中的所有字母异位词

本题取自LeetCode hoot 100 题号438 找到字符串中的所有字母异位词

一 题目概述

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

示例 1:

复制代码
输入: s = "cbaebabacd", p = "abc"
输出: [0,6]
解释:
起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。
起始索引等于 6 的子串是 "bac", 它是 "abc" 的异位词。

二 思路解析

遇到类似判断子串问题,很容易想到双重循环求子串,再判断是否满足条件。时间复杂度过高,在此我们可以利用 '滑动窗口' ,顾名思义,设置一个子串大小的窗口,并不断向前推进。

不妨以题目所给示例加以说明:

s = "cbaebabacd", p = "abc" 规定初始窗口在前三个字符cba 考虑到需要判断是否是异位词,就是要判断每个字母出现的次数是否和p相同,我们不妨设置两个数组,一个记录p中各个字母出现次数,一个记录s的子串中各个字母出现次数。

很显然cba 符合abc的异位词。向前推进至 bce 不符合异位词 abc。依次类推 下面是图示说明:

三 代码解析

cpp 复制代码
#include <iostream>
#include <vector>
#include <map>
using namespace std;

int main()
{
	string s, p;
	cin >> s >> p;
	vector<int>res;//记录匹配位置
	map<char, int>pMap;//记录模式串中每个字符出现的次数
	map<char, int>sMap;//记录主串中每个字符出现的次数
	//统计模式串中每个字符出现的次数
	for (char c : p)
	{
		pMap[c]++;
	}

	for (int i = 0; i < p.size(); i++) sMap[s[i]]++;//初始化窗口,统计主串中前p.size()个字符出现的次数
	if (sMap == pMap) res.push_back(0);//如果初始窗口匹配,记录位置0

	//滑动窗口,统计主串中每个字符出现的次数 i记录起始索引 注意数组越界
	for (int i = 1; i <= s.size()-p.size(); i++)
	{
		//窗口向右滑动,更新sMap
		sMap[s[i-1]]--;
		if (sMap[s[i - 1]] == 0) sMap.erase(s[i - 1]);
		sMap[s[i + p.size() - 1]]++;
		if (sMap == pMap) res.push_back(i);
		
	}
	for (int i = 0; i < res.size(); i++)
	{
		cout << res[i] << " ";
	}
	return 0;
}

值得注意的是 我利用map记录字母(key)和其对应的出现次数(value),然而本题只出现了小写字母,我们可以利用数组替代map,数组大小为26 对应26个小写字母。数组效率一般高于map。

感谢阅读。

相关推荐
Navigator_Z2 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
云泽8085 小时前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法
wlsh155 小时前
Go 迭代器
算法
语戚6 小时前
力扣 3161. 块放置查询:线段树解法(Java 实现)
java·算法·leetcode·面试·线段树·力扣·
天天进步20156 小时前
Python全栈项目实战:从零构建校园心理健康咨询平台
面试·职场和发展
CS创新实验室6 小时前
从顺序表到动态数组:数据结构的永恒基石与现代语言的优雅封装
数据结构·算法
Black蜡笔小新7 小时前
自动化AI算法训练服务器DLTM训推一体化平台助力农业生产管理实现安全智能化
人工智能·算法·自动化
武子康7 小时前
调查研究-151 Slack vs Jira:区别、使用指南与团队选择方法
人工智能·科技·深度学习·ai·职场和发展·jira·slack
8Qi88 小时前
LeetCode 23. 合并 K 个升序链表 —— 小顶堆(PriorityQueue)
数据结构·算法·leetcode·链表·
QiLinkOS8 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源