LeetCode 第30题 Substring with Concatenation of All Words【滑动窗口】(Java)

栏目: Java · 发布时间: 6年前

内容简介:原题地址为:我的解题思路是这样的,首先这样的子串,一定也是words里面单词练在一起的某个组合。那么我们可以先调用438题目的函数findAnagrams。这样就大大减少了选项。然后,我们从返回的list去检查,每一个子串,是否包含了words里面的单词,所以代码也不复杂。

原题地址为: https://leetcode.com/problems/substring-with-concatenation-of-all-words/

要求

给定字符串s,和有一个单词列表words,每个词长度相等。在s中寻找,包含全部词,且每个词只出现一次,没有任何多余其他字符的子串。

例 1:

输入:

s = “barfoothefoobarman”,

words = [“foo”,”bar”]

输出:  [0,9]

0,9分别对应了”barfoor”和”foobar”

例 2:

输入:

s = “wordgoodgoodgoodbestword”,

words = [“word”,”good”,”best”,”word”]

输出: []

我的解题思路是这样的,首先这样的子串,一定也是words里面单词练在一起的某个组合。那么我们可以先调用438题目的函数findAnagrams。这样就大大减少了选项。

然后,我们从返回的list去检查,每一个子串,是否包含了words里面的单词,所以代码也不复杂。

不包含findAnagrams实现的话,包含两个函数,一个是checkwords,看看一个子串是否包含words里面的单词。另外一个函数是结果函数 findSubstring。

LeetCode 第30题 Substring with Concatenation of All Words【滑动窗口】(Java)
LeetCode 第30题 Substring with Concatenation of All Words【滑动窗口】(Java)

这个做起来简单,但是性能一般,执行需要94ms。问题应该出在checkwords的实现,不过我暂时懒得优化了,毕竟这次主要目的是练习滑动窗口的技巧。

本题代码地址为: https://github.com/tinyfool/leetcode/tree/master/src/p0030

本文假设你对滑动窗口概念有所了解,如果你对滑动窗口的概念不够了解,请参看我介绍 滑动窗口的文章,里面有详细的解释


以上所述就是小编给大家介绍的《LeetCode 第30题 Substring with Concatenation of All Words【滑动窗口】(Java)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

模糊数学基础及实用算法

模糊数学基础及实用算法

李鸿吉编 / 科学出版社 / 2005-1 / 55.00元

本书开发了模糊数学常用的计算机程序,并以大量的算例系统地介绍了模糊数学的实用算法。本书可以作为模糊数学的应用程序包,在详细解释源代码的同时,对应用程序开发所用到的Visual Basic 6.0方法做了系统介绍,其目的是为读者做进一步的自主开发提供便利。本书所提供的源程序可以作为读者自主开发的素材。本书配有光盘,分章节提供程序源代码。 本书可以作为大专院校、培训班的教学参考书。对需......一起来看看 《模糊数学基础及实用算法》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

随机密码生成器
随机密码生成器

多种字符组合密码