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

目录

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

题目描述:

实现代码与解析:

滑动窗口

原理思路:


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

题目描述:

给你两个字符串 word1word2

如果一个字符串 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
  • word1word2 都只包含小写英文字母。

实现代码与解析:

滑动窗口

java 复制代码
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。

相关推荐
前进之路91 分钟前
Leetcode每日一练--35
算法·leetcode
焰火19992 分钟前
[Java]Redisson的分布式锁及看门狗机制
java·后端
zz-zjx17 分钟前
JVM垃圾收集器详解(jdk21+25实战版)
java·开发语言·jvm
摇滚侠25 分钟前
Spring Boot 3零基础教程,Spring Boot 日志级别,笔记19
java·spring boot·笔记
zl97989942 分钟前
SpringBoot-配置文件yaml
java·spring boot·spring
好家伙VCC1 小时前
**TensorFlow:发散创新的深度学习框架探索**随着人工智
java·人工智能·python·深度学习·tensorflow
微笑尅乐1 小时前
三种思路彻底掌握 BST 判断(递归与迭代全解析)——力扣98.验证二叉搜索树
算法·leetcode·职场和发展
豆沙沙包?1 小时前
2025年--Lc194-516. 最长回文子序列(动态规划在字符串的应用,需要二刷)--Java版
java·算法·动态规划
_extraordinary_1 小时前
Java Spring配置
java·开发语言·spring
工业甲酰苯胺2 小时前
Java并发机制的底层实现原理:从CPU到JVM的全面解析
java·jvm·spring