欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 产业 > LeetCode:3297. 统计重新排列后包含另一个字符串的子字符串数目 I(滑动窗口 Java)

LeetCode:3297. 统计重新排列后包含另一个字符串的子字符串数目 I(滑动窗口 Java)

2025/1/19 2:38:53 来源:https://blog.csdn.net/Cosmoshhhyyy/article/details/145043588  浏览:    关键词:LeetCode:3297. 统计重新排列后包含另一个字符串的子字符串数目 I(滑动窗口 Java)

目录

3297. 统计重新排列后包含另一个字符串的子字符串数目 I

题目描述:

实现代码与解析:

滑动窗口

原理思路:


3297. 统计重新排列后包含另一个字符串的子字符串数目 I

题目描述:

        给你两个字符串 word1 和 word2 。

如果一个字符串 x 重新排列后,word2 是重排字符串的 

前缀

 ,那么我们称字符串 x 是 合法的 。

请你返回 word1 中 合法 

子字符串

 的数目。

示例 1:

输入:word1 = "bcca", word2 = "abc"

输出:1

解释:

唯一合法的子字符串是 "bcca" ,可以重新排列得到 "abcc" ,"abc" 是它的前缀。

示例 2:

输入:word1 = "abcabc", word2 = "abc"

输出:10

解释:

除了长度为 1 和 2 的所有子字符串都是合法的。

示例 3:

输入:word1 = "abcabc", word2 = "aaabc"

输出:0

解释:

  • 1 <= word1.length <= 105
  • 1 <= word2.length <= 104
  • word1 和 word2 都只包含小写英文字母。

实现代码与解析:

滑动窗口

class Solution {public long validSubstringCount(String word1, String word2) {if (word1.length() < word2.length()) {return 0;}int[] hash = new int[26];// 种类int cnt = 0;for (char c : word2.toCharArray()) {if (hash[c - 'a']++ == 0) cnt++;}int[] cur = new int[26];long res = 0;for (int l = 0, r = 0; r < word1.length(); r++) {if (++cur[word1.charAt(r) - 'a'] == hash[word1.charAt(r) - 'a']) {cnt--;}while (cnt == 0) {if (cur[word1.charAt(l) - 'a'] == hash[word1.charAt(l) - 'a']) {cnt++;}cur[word1.charAt(l) - 'a']--;l++;}res += l;}return res;}
}

原理思路:

        题目含义:求在 word1 中,有多少个子串包含 word2 中的所有字符。

        hash记录字母出现次数,cnt记录当前还需要的满足条件的字母的数量。

        如果我们在word1中找到了一个最短的子串s(假设s=word[l,r])包含了所有的word2的字符,那么: word1[0:r],word1[1:r],word1[2:r],...,word[l,r]都符合条件,这些子串的个数是l+1。        

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com