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

【算法题】30. 串联所有单词的子串

题目

给定一个字符串 s 和一个字符串数组 words。 words 中所有字符串 长度相同。

 s 中的 串联子串 是指一个包含  words 中所有字符串以任意顺序排列连接起来的子串。

例如,如果 words = ["ab","cd","ef"], 那么 "abcdef", "abefcd","cdabef", "cdefab","efabcd", 和 "efcdab" 都是串联子串。 "acdbef" 不是串联子串,因为他不是任何 words 排列的连接。
返回所有串联子串在 s 中的开始索引。你可以以 任意顺序 返回答案。

示例 1:

输入:s = "barfoothefoobarman", words = ["foo","bar"]
输出:[0,9]
解释:因为 words.length == 2 同时 words[i].length == 3,连接的子字符串的长度必须为 6。
子串 "barfoo" 开始位置是 0。它是 words 中以 ["bar","foo"] 顺序排列的连接。
子串 "foobar" 开始位置是 9。它是 words 中以 ["foo","bar"] 顺序排列的连接。
输出顺序无关紧要。返回 [9,0] 也是可以的。
示例 2:

输入:s = "wordgoodgoodgoodbestword", words = ["word","good","best","word"]
输出:[]
解释:因为 words.length == 4 并且 words[i].length == 4,所以串联子串的长度必须为 16。
s 中没有子串长度为 16 并且等于 words 的任何顺序排列的连接。
所以我们返回一个空数组。
示例 3:

输入:s = "barfoofoobarthefoobarman", words = ["bar","foo","the"]
输出:[6,9,12]
解释:因为 words.length == 3 并且 words[i].length == 3,所以串联子串的长度必须为 9。
子串 "foobarthe" 开始位置是 6。它是 words 中以 ["foo","bar","the"] 顺序排列的连接。
子串 "barthefoo" 开始位置是 9。它是 words 中以 ["bar","the","foo"] 顺序排列的连接。
子串 "thefoobar" 开始位置是 12。它是 words 中以 ["the","foo","bar"] 顺序排列的连接。
 

提示:

1 <= s.length <= 10^4
1 <= words.length <= 5000
1 <= words[i].length <= 30
words[i] 和 s 由小写英文字母组成

题解

class Solution {public List<Integer> findSubstring(String s, String[] words) {List<Integer> res = new ArrayList<Integer>();int m = words.length, n = words[0].length(), ls = s.length();for (int i = 0; i < n; i++) {if (i + m * n > ls) {break;}Map<String, Integer> differ = new HashMap<String, Integer>();for (int j = 0; j < m; j++) {String word = s.substring(i + j * n, i + (j + 1) * n);differ.put(word, differ.getOrDefault(word, 0) + 1);}for (String word : words) {differ.put(word, differ.getOrDefault(word, 0) - 1);if (differ.get(word) == 0) {differ.remove(word);}}for (int start = i; start < ls - m * n + 1; start += n) {if (start != i) {String word = s.substring(start + (m - 1) * n, start + m * n);differ.put(word, differ.getOrDefault(word, 0) + 1);if (differ.get(word) == 0) {differ.remove(word);}word = s.substring(start - n, start);differ.put(word, differ.getOrDefault(word, 0) - 1);if (differ.get(word) == 0) {differ.remove(word);}}if (differ.isEmpty()) {res.add(start);}}}return res;}
}

来自力扣官方题解

相关文章:

  • 如何使用ArcGIS Pro将Excel表转换为SHP文件
  • 14.用户管理
  • CentOS 5/6/7 基于开源项目制作openssh 9.6p1 rpm包—— 筑梦之路
  • 小程序wx:if 和hidden的区别?
  • Spring Data Redis对象缓存序列化问题
  • K8S Helm 安装ingress-nginx/ingress-nginx
  • 阿里云ECS云服务器优势整理(共9点)
  • LabVIEW在大型风电机组状态监测系统开发中的应用
  • 视频格式网络地址转换视频到本地,获取封面、时长,其他格式转换成mp4
  • 每日一题——LeetCode976
  • Python 下载与安装
  • C#,入门教程(01)—— Visual Studio 2022 免费安装的详细图文与动画教程
  • 2023 年中国金融级分布式数据库市场报告:TiDB 位列领导者梯队,创新能力与增长指数表现突出
  • 使用nodejs定时备份mysql数据库与恢复
  • sklearn 中matplotlib编制图表
  • 《Java编程思想》读书笔记-对象导论
  • C++入门教程(10):for 语句
  • Fastjson的基本使用方法大全
  • Java多线程(4):使用线程池执行定时任务
  • Laravel Mix运行时关于es2015报错解决方案
  • learning koa2.x
  • Leetcode 27 Remove Element
  • Odoo domain写法及运用
  • SQL 难点解决:记录的引用
  • vue中实现单选
  • 阿里研究院入选中国企业智库系统影响力榜
  • 初识 beanstalkd
  • 分布式任务队列Celery
  • 湖南卫视:中国白领因网络偷菜成当代最寂寞的人?
  • 简单易用的leetcode开发测试工具(npm)
  • 讲清楚之javascript作用域
  • 使用Swoole加速Laravel(正式环境中)
  • 再谈express与koa的对比
  • zabbix3.2监控linux磁盘IO
  • 东超科技获得千万级Pre-A轮融资,投资方为中科创星 ...
  • 关于Android全面屏虚拟导航栏的适配总结
  • ​人工智能书单(数学基础篇)
  • #include到底该写在哪
  • (1)Map集合 (2)异常机制 (3)File类 (4)I/O流
  • (4)STL算法之比较
  • (C++17) optional的使用
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (WSI分类)WSI分类文献小综述 2024
  • (ZT)薛涌:谈贫说富
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (完整代码)R语言中利用SVM-RFE机器学习算法筛选关键因子
  • (一)Spring Cloud 直击微服务作用、架构应用、hystrix降级
  • (转)Linux整合apache和tomcat构建Web服务器
  • ****** 二十三 ******、软设笔记【数据库】-数据操作-常用关系操作、关系运算
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter
  • .NET运行机制
  • :中兴通讯为何成功
  • @transaction 提交事务_【读源码】剖析TCCTransaction事务提交实现细节
  • [].slice.call()将类数组转化为真正的数组
  • [《百万宝贝》观后]To be or not to be?