【Java刷题篇】串联所有单词的子串

这里写目录标题

  • 📃1.题目
  • 📜2.分析题目
  • 📜3.算法原理
  • 🧠4.思路叙述
    • ✍1.进窗口
    • ✍2.判断有效个数
    • ✍3.维护窗口
    • ✍4.出窗口
  • 💥5.完整代码

📃1.题目

力扣链接: 串联所有单词的子串
在这里插入图片描述
在这里插入图片描述

📜2.分析题目

阅读题目后,可以拿到一个关键信息–words中所有字符串长度相等,这后续解题思路的一大关键,还有就是串联字串的字符串顺序可以不同。得到这两个关键信息后,我们就很容易联想到运用滑动窗口这个算法来解决问题。
好分析完题目后,我们就开始讲解算法的原理,如果你懂得滑动窗口的原理话,可以跳过直接观看算法原理的讲解。

📜3.算法原理

在此篇文章前,已经发布关于滑动窗口的讲解。
博客链接: 滑动窗口

🧠4.思路叙述

先前滑动窗口解决的问题,要么是一个数字一个数字进行遍历,要么是一个字符一个字符进行遍历,今天这题与众不同的是以一个字符串为单位进行遍历,使用哈希表来进行存储。

  • 我们创建两个哈希表。
  • 我们将words中的字符串存入哈希表1中。
  • 我们在循环遍历s的过程中,每遍历一个字符串就将其加入哈希表2中
  • 并且同时进行有效个数的判断以及维护窗口
  • 最后通过有效个数的比较返回值

✍1.进窗口

还是定义left和right左右指针来对窗口进行划分。每一次right和left指针递增的长度是words中字符串的长度,此时有一个难题,那就是从什么位置开始遍历呢?从第一个字符的位置开始遍历?
在这里插入图片描述
那么这种情况该如何处理?这种情况行不通,我们可以每个位置都进行尝试
从0–len的位置都进行尝试,这样就完美的解决了这个问题。
在这里插入图片描述

 int len = words[0].length();for (int i = 0; i < len; i++) {//整体大循环控制}

✍2.判断有效个数

我们创建两个哈希表。

HashMap<String,Integer> hashMap1 = new HashMap<>();
HashMap<String,Integer> hashMap2 = new HashMap<>();

我们将words中的字符串存入哈希表1中。

for (String ss:words) {hashMap1.put(ss, hashMap1.getOrDefault(ss,0)+1);}

首先确定循环的条件,由上述讲解中已经提到right的起始位置

 for (int right = i,left = i,count = 0; right+len <= s.length() ; right+= len) {}

我们在循环遍历s的过程中,每遍历一个字符串就将其加入哈希表2中,并且与哈希表1中存入的字符串进行比较,如果相同,有效个数就+1

   String in = s.substring(right,right+len);hashMap2.put(in,hashMap2.getOrDefault(in,0)+1);if (hashMap2.get(in) <= hashMap1.getOrDefault(in,0)){count++;}

✍3.维护窗口

再次过程中,我们要保证窗口的大小。同words中字符个数相等的窗口。

     int len = words[0].length();int m = words.length;if (right - left +1 > m*len){//出窗口}

✍4.出窗口

  String out = s.substring(left,left+len);if (hashMap2.get(out) <= hashMap1.getOrDefault(out,0)){count--;}hashMap2.put(out,hashMap2.get(out)-1);left+= len;

💥5.完整代码

 public List<Integer> findSubstring(String s, String[] words) {List<Integer> list = new ArrayList<>();int len = words[0].length();int m = words.length;HashMap<String,Integer> hashMap1 = new HashMap<>();for (String ss:words) {hashMap1.put(ss, hashMap1.getOrDefault(ss,0)+1);}//大条件for (int i = 0; i < len; i++) {HashMap<String,Integer> hashMap2 = new HashMap<>();//入口位置的处理for (int right = i,left = i,count = 0; right+len <= s.length() ; right+= len) {//进窗口String in = s.substring(right,right+len);hashMap2.put(in,hashMap2.getOrDefault(in,0)+1);//有效个数的判断if (hashMap2.get(in) <= hashMap1.getOrDefault(in,0)){count++;}//窗口大小的维护if (right - left +1 > m*len){//出窗口String out = s.substring(left,left+len);if (hashMap2.get(out) <= hashMap1.getOrDefault(out,0)){count--;}hashMap2.put(out,hashMap2.get(out)-1);left+= len;}//判断条件是否符合要求if (count == m){list.add(left);}}}return list;}

以上就是所有内容,如果对你有帮助的话,点赞收藏支持一下吧!💞💞💞

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

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

相关文章

口腔管理平台 |基于springboot框架+ Mysql+Java+B/S结构的口腔管理平台 设计与实现(可运行源码+数据库+lw文档)

推荐阅读100套最新项目 最新ssmjava项目文档视频演示可运行源码分享 最新jspjava项目文档视频演示可运行源码分享 最新Spring Boot项目文档视频演示可运行源码分享 目录 前台功能效果图 管理员功能登录前台功能效果图 会员功能 系统功能设计 数据库E-R图设计 lunwen参考…

智慧公厕建设的主要目标是什么?

随着城市化进程的不断推进&#xff0c;公共厕所作为城市基础设施的重要组成部分&#xff0c;也变得越来越重要。为了提升公共厕所的管理水平、提供更好的服务质量&#xff0c;智慧公厕应运而生。智慧公厕的建设旨在通过信息化手段实现公共厕所的全面感知监测&#xff0c;实现公…

remix Gas estimation failed,Remix中合约编译后的ABI以及bytecode位置,Remix中合约编译后的怎么测试

目录 remix Gas estimation failed Remix中合约编译后的ABI以及bytecode位置 Remix中合约编译后的怎么测试 remix Gas estimation failed 很有可能是你的solidity版本问题,重新复制我下编的,进行部署;

【Linux笔记-使用指南-备忘录】

虚拟机使用指南 创建虚拟机Linux使用指南yumJDKDockerLinux常用指令 RedisRedis配置key相关指令String相关指令待续... 创建虚拟机 点击我创建虚拟机 Linux使用指南 yum # 更新yum包 sudo yum update -y# 加入安装过旧版本&#xff0c;先卸载旧版本 sudo yum remove docker…

redis的基本知识点

连接Redis 在进行Redis操作之前&#xff0c;首先需要连接到Redis服务器。这可以通过使用redis-cli命令实现&#xff0c;具体命令格式如下&#xff1a; redis-cli -h <host> -p <port>其中&#xff0c;是Redis服务器的主机名或IP地址&#xff0c;是Redis服务器的端…

C语言自定义数据类型:用typedef声明新类型名

参考原文链接&#xff1a;https://blog.csdn.net/qq_57342311/article/details/129616215 除了可以直接使用 C 提供的标准类型名(如 int&#xff0c;char&#xff0c;float, double 和 long 等)和程序编写者自己声明的结构体、共用体、枚举类型外&#xff0c;还可以用 typedef …

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:FormLink)

提供静态卡片交互组件&#xff0c;用于静态卡片内部和提供方应用间的交互&#xff0c;当前支持router、message和call三种类型的事件。 说明&#xff1a; 该组件从API Version 10开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 该组件仅可…

6.【Linux】进程间通信(管道命名管道||简易进程池||简易客户端服务端通信)

介绍 进程间通信的方式 1.Linux原生支持的管道----匿名和命名管道 2.System V-----共享内存、消息队列、信号量 3.Posix------多线程、网路通信 进程间通信目的 数据传输&#xff1a;一个进程需要将它的数据发送给另一个进程 资源共享&#xff1a;多个进程之间共享同样的资源。…

Android存储概念及路径解析

Android存储概念及路径解析 在Android开发领域&#xff0c;理解不同的存储类型及其对应的文件系统路径对于设计和实现应用至关重要。本文将深入探讨内部存储、外部存储、内存和缓存的概念&#xff0c;并阐明storage/sdcard与mnt/sdcard的区别&#xff0c;以及/storage/emulate…

【C++刷题】优选算法——动态规划第一辑

1.状态表示是什么&#xff1f;简答理解是dp表里的值所表示的含义怎么来的&#xff1f;题目要求经验题目要求分析问题的过程中&#xff0c;发现重复子问题 2.状态转移方程dp[i]......细节问题&#xff1a;3.初始化控制填表的时候不越界4.填表顺序控制在填写当前状态的时候&#…

腾讯云免费服务器配置大全和个人企业申请流程,2024年新版教程

腾讯云免费服务器申请入口 https://curl.qcloud.com/FJhqoVDP 免费服务器可选轻量应用服务器和云服务器CVM&#xff0c;轻量配置可选2核2G3M、2核8G7M和4核8G12M&#xff0c;CVM云服务器可选2核2G3M和2核4G3M配置&#xff0c;腾讯云服务器网txyfwq.com分享2024年最新腾讯云免费…

蓝桥杯每日一题——棋盘

问题描述 小蓝拥有 n xn 大小的棋盘&#xff0c;一开始棋盘上全都是白子。小蓝进行了 m 次操作&#xff0c;每次操作会将棋盘上某个范围内的所有棋子的颜色取反(也就是白色棋子变为黑色&#xff0c;黑色棋子变为白色)请输出所有操作做完后棋盘上每个棋子的颜色。输入格式 输入的…

【每日前端面经】2024-03-17

【每日前端面经】2024-03-17 本期重点 —— Promise 欢迎订阅我的前端面经专栏&#xff1a;每日前端面经 Tips:每日面经更新从 2-22 到 3-15 已有 23 篇&#xff0c;最近愈发觉得内容相似度高&#xff0c;并且理解程度不深 于是临时停更面经&#xff0c;并将这些面经中的重…

卷积神经网络算法原理(卷积层,卷积运算,填充,步幅,经过卷积运算后的特征图大小,池化层,最大池化,平均池化,经过池化层运算后的特征图大小)

文章目录 卷积神经网络算法原理(卷积层&#xff0c;卷积运算&#xff0c;填充&#xff0c;步幅&#xff0c;经过卷积运算后的特征图大小&#xff0c;池化层&#xff0c;最大池化&#xff0c;平均池化&#xff0c;经过池化层运算后的特征图大小)前言1、图像的本质1.1、灰度图1.2…

Java学习笔记(16)

常见算法 查找算法 查询某个元素是否存在 二分查找&#xff08;数组元素必须是有序的&#xff09; package exercise;public class exercise1 {public static void main(String[] args) {int[] arr {7, 23, 797, 23, 79, 81, 103, 127, 131, 147};System.out.println(binar…

实战Python Socket编程:开发多用户聊天应用

实战Python Socket编程&#xff1a;开发多用户聊天应用 Python Socket 编程概述什么是Socket编程&#xff1f;Socket编程的应用场景Socket编程的重要性基本概念 环境准备Python版本必要的库开发环境配置调试工具 基本Socket编程创建Socket绑定Socket到端口监听连接接受连接发送…

C语言经典面试题目(七)

1、C语言中如何进行内存对齐和字节对齐&#xff1f; 在C语言中&#xff0c;内存对齐和字节对齐是为了优化内存访问速度和提高系统性能而进行的一种策略。内存对齐是指数据在内存中的存放位置必须是某个值的倍数&#xff0c;通常是数据类型的大小。字节对齐是指数据在内存中的存…

24.第12届蓝桥杯省赛真题题解

A.空间&#xff08;100%&#xff09; 计算机存储单位计算 1TB2^10 GB 1GB2^10 MB 1MB2^10 KB 1KB2&10 B 1B8 bit(bit位二进制的最小的存储单位) #include <iostream> #include <cmath>using namespace std; //2^28B 2^2int main(){std::ios::sync_with_stdio…

【C语言入门】浮点型数据在内存中的存储

✨✨欢迎大家来到Celia的博客✨✨ &#x1f389;&#x1f389;创作不易&#xff0c;请点赞关注&#xff0c;多多支持哦&#x1f389;&#x1f389; 所属专栏&#xff1a;C语言 个人主页&#xff1a;Celias blog~ 目录 ​编辑 引言 引例 一、浮点型在内存中的存储方式 1.1 …

在idea中配置tomcat服务器,然后部署一个项日

1.下载tomcat Tomcat下载 点击右边的tomcat8 找到zip点击下载 下载完&#xff0c;解压到你想放置的路径下 2.配置环境变量 打开设置找到高级系统设置点击环境变量 点击新建&#xff0c;变量名输入&#xff1a;CATALINA_HOME&#xff0c;变量值就是Tomcat的安装路径&#x…