算法---滑动窗口练习-6(找到字符串中所有字母异位词)

news2024/11/20 15:29:40

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

  • 1. 题目解析
  • 2. 讲解算法原理
  • 3. 编写代码

1. 题目解析

题目地址:找到字符串中所有字母异位词

在这里插入图片描述

2. 讲解算法原理

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

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


算法的基本思想是使用滑动窗口来遍历字符串s,并利用两个哈希表(hash1和hash2)来统计窗口中字符的频次。

具体的算法步骤如下:

  1. 初始化两个长度为26的数组hash1和hash2,用于记录字符串的字符频次。初始时,数组中所有元素都为0。

  2. 遍历字符串p,将其中的字符映射到hash2数组中,并增加相应字符的频次。

  3. 定义两个指针left和right,初始时都指向字符串s的第一个字符。

  4. 进入循环,循环条件为right指针小于字符串s的长度。

    • 在循环中,首先将当前right指针指向的字符加入窗口,即将hash1数组中对应字符的频次加1。

    • 检查加入窗口的字符是否是有效字符,即其频次小于等于hash2数组中对应字符的频次。如果是有效字符,则将计数器count加1。

    • 检查窗口大小是否超过了字符串p的长度,即right-left+1是否大于len2。如果超过了窗口大小,则需要移动窗口。

    • 移动窗口的过程包括以下几个步骤:

      • 检查窗口左侧字符是否是有效字符,即其频次小于等于hash2数组中对应字符的频次。如果是有效字符,则将计数器count减1。
      • 将窗口左侧字符从窗口中移除,即将hash1数组中对应字符的频次减1。
      • 将左指针left向右移动一位。
    • 检查计数器count是否等于字符串p的长度len2。如果相等,则表示当前窗口是一个字母异位词,将左指针left的位置加入结果集ret。

    • 将右指针right向右移动一位,继续循环。

  5. 循环结束后,返回结果集ret,其中包含了所有字母异位词的起始位置。


3. 编写代码


class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
        int hash1[26]={0},hash2[26]={0};
        int left=0,right=0,len2=p.size(),len1=s.size();
        vector<int> ret; 
        for(auto ch:p)hash2[ch-'a']++;
        int count=0;
        //利用变量count来统计窗口中“有效字符”的个数
        while(right<len1)
        {    
            hash1[s[right]-'a']++;//进窗口
            if(hash1[s[right]-'a']<=hash2[s[right]-'a'])
            {
                count++;
            }
            if(right-left+1>len2)
            {
                if(hash1[s[left]-'a']<=hash2[s[left]-'a'])
                {
                    count--;
                }
                hash1[s[left]-'a']--;
                left++;
            }
            if(count==len2)
            ret.push_back(left);
            
            right++;
        }
        return ret;
    }
};

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

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

相关文章

GPD<论文精简版>

问题陈述 给定点云数据、机械手的几何参数&#xff0c;抓取位姿检测问题&#xff08; grasp pose detection problem&#xff09;表示为&#xff0c;在抓手闭合情况下&#xff0c;识别抓手的配置的问题。 &#xff1a;机器人工作空间 &#xff1a;三维点云中的一组点&#x…

数据结构(三)——数组和特殊矩阵

一维数组的存储结构 各数组元素大小相同&#xff0c;且物理上连续存放。 数组元素a[i] 的存放地址 LOC i * sizeof(ElemType) (0≤i<10)注&#xff1a;除非题目特别说明&#xff0c;否则数组下标默认从0开始 二维数组的存储结构 M行N列的二维数组 b[M][N] 中&#xff0c;…

MySQL联合索引的底层存储结构

1、底层存储结构 2、几点思考 1、先按照name排序&#xff0c;name相同的基础上&#xff0c;在按照age进行排序&#xff0c;age相同的基础上&#xff0c;在按照position排序。 2、为什么会有“最左匹配原则”&#xff0c;因为从上图可以清除的看到&#xff0c;如果不使用name字…

tslearn,一个实用的 Python 库!

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com 大家好&#xff0c;今天为大家分享一个实用的 Python 库 - tslearn。 Github地址&#xff1a;https://github.com/tslearn-team/tslearn 在数据科学领域&#xff0c;时间序列分析是一项至关重要的任务&#xff…

11个销售心理学方法,帮你搞定老外!销售高手教你第一次见客户聊什么?

PART01 客户的疑问 销售心理学中&#xff0c;站在客户的角度&#xff0c;客户都会有以下几个疑问&#xff1a; 1、你是谁&#xff1f; 2、你要跟我介绍什么&#xff1f; 3、你介绍的产品和服务对我有什么好处&#xff1f; 4、如何证明你介绍的是真实的&#xff1f; 5、为…

Java多线程实战-异步操作日志记录解决方案(AOP+注解+多线程)

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️本系列源码仓库&#xff1a;多线程并发编程学习的多个代码片段(github) &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正…

商家转账到零钱 场景模板怎么下载

商家转账到零钱是什么&#xff1f; 【商家转账到零钱】功能整合了微信支付之前的【企业付款到零钱】【批量转账到零钱】功能&#xff0c;支持批量对外转账&#xff0c;对有批量对用户付款需求的应用场景更友好&#xff0c;操作便捷。如果你的应用场景是单付款场景的话&#xf…

数据安全之认识数据库加密系统

文章目录 一、什么是数据库加密系统二、数据库加密系统的工作原理三、数据库加密系统的核心功能四、数据库加密系统的特点和优势五、数据库加密系统的部署方式1、在线透明部署2、旁路代理模式 六、数据库加密系统的应用场景 数据库作为计算机信息系统的核心组成部分&#xff0c…

使用vscode——配置vue3用户代码片段

一、 设置/配置用户代码片段 二、点击新建全局代码片段文件输入vue.json 三、配置代码片段、 {"Print to console": {"prefix": "vue3","body": ["<template>"," <div></div>","</te…

JAVA22 FFM实战之HelloWorld

前言 JDK22即将发布&#xff0c;Java Foreign Function & Memory API将会退出预览&#xff0c;是时候开始学习一波了。 FFM API介绍 FFM API由两大部分组成&#xff0c;一个是Foreign Function Interface&#xff0c;另一个是Memory API。前者是外部函数接口&#xff0c…

数据结构 之 队列(Queue)

​​​​​​​ &#x1f389;欢迎大家观看AUGENSTERN_dc的文章(o゜▽゜)o☆✨✨ &#x1f389;感谢各位读者在百忙之中抽出时间来垂阅我的文章&#xff0c;我会尽我所能向的大家分享我的知识和经验&#x1f4d6; &#x1f389;希望我们在一篇篇的文章中能够共同进步&#xff0…

双指针算法_移动零_

题目&#xff1a; 给定一个数组 num &#xff0c;编写一个函数将数组内部的数字0都移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序&#xff01; 同时不能通过复制数组&#xff0c;开辟新的数组空间的情况下原地对数组进行操作 示例&#xff1a; 本题的原理&#x…

掘根宝典之C++普通迭代器和反向迭代器详解

简介 迭代器是一种用于遍历容器元素的对象。它提供了一种统一的访问方式&#xff0c;使程序员可以对容器中的元素进行逐个访问和操作&#xff0c;而不需要了解容器的内部实现细节。 C标准库里每个容器都定义了迭代器&#xff0c;这迭代器的名字就叫容器迭代器 迭代器的作用类…

谷歌浏览器运行vue项目。 控制台打印cjs.js,如何解决

当浏览器运行vue项目。 控制台打印cjs.js&#xff0c;如何解决 &#xff1a;

oracle基础-子查询 备份

一、什么是子查询 子查询是在SQL语句内的另外一条select语句&#xff0c;也被称为内查询活着内select语句。在select、insert、update、delete命令中允许是一个表达式的地方都可以包含子查询&#xff0c;子查询也可以包含在另一个子查询中。 【例1.1】在Scott模式下&#xff0…

Java项目企业设备管理系统

java项目企业设备管理系统javaweb项目ssm框架项目 运行环境:idea/eclipse tomcat jdk mysql navicat 系统用户分为员工和管理员两类用户。两类用户都可以进行系统的登录&#xff0c;虽然进入的系统主页结构相似&#xff0c;但是在功能上有不同。员工的密码可以自己进入系统后…

DirectShowPlayerService::doSetUrlSource: Unresolved error code 0x800c000d

报出这个问题&#xff0c;应该是对给的url解析不正确&#xff0c;我给的是rtsp的视频流地址&#xff0c;应该是对该格式解析异常。 所以参考两篇文&#xff1a; QT无法播放视频&#xff1a;报错&#xff1a;DirectShowPlayerService::doRender: Unresolved error code 0x8004…

2024年3月16日云仓酒庄广西发布会圆满举行

原标题&#xff1a;云仓酒庄广西发布会圆满举行&#xff0c;致敬经销商团队共谋未来发展 2024年3月16日&#xff0c;备受瞩目的云仓酒庄广西发布会在广西南宁隆重举行。此次发布会旨在感谢广西地区经销商团队的长期支持&#xff0c;并共同推进未来发展蓝图。活动现场氛围热烈&…

总要有一次,为自己疯狂

机会其实不多 最近一口气看了《飞驰人生》以及《飞驰人生2》&#xff0c;过去是以看喜剧的心态去看沈腾的电影&#xff0c;当如今二刷时发现这不就是生活吗&#xff0c;只不过用喜剧的外壳做了层包装。两部电影给我影响最深的就是最后的那段对白&#xff0c;“张弛&#xff0c…

【大模型系列】统一图文理解与生成(BLIP/BLIPv2/InstructBLIP)

文章目录 1 BLIP(2022, Salesforce Research)1.1 简介1.2 数据角度1.3 模型角度1.4 BLIP预训练的目标 2 BLIP2(ICML2023, Salesforce)2.1 简介2.2 模型架构2.3 训练细节 3 InstructBLIP(2023, Salesforce)3.1 指令微调技术(Instruction-tuning)3.2 数据集准备3.3 Instruction-a…