【从零开始的LeetCode-算法】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 <= 10^5
  • 1 <= word2.length <= 10^4
  • word1word2 都只包含小写英文字母。

我的解答

java 复制代码
class Solution {
    public long validSubstringCount(String word1, String word2) {
        int len1 = word1.length(), len2 = word2.length();
        // 记录word2中字母出现的次数
        int[] pre = new int[26];
        // 记录word2中的字母在word1中出现的次数
        int[] p = new int[26];
        for(char ch : word2.toCharArray()){
            pre[ch - 'a']++;
        }
        long res = 0;
        int left = 0;
        for(int i = 0; i < len1 ; i++){
            int ch = word1.charAt(i) - 'a';
            p[ch]++;
            if(pre[ch] > 0 && p[ch] <= pre[ch]) len2--;
            // 右遍历找到刚好包含word2中所有单词的子字符串后,收拢左边区域
            if(len2 <= 0){
                // 右边剩余单词可与当前字符串构成的组合
                long ans = len1 - i;
                long count = 0;
                while(left <= i){
                    int left_ch = word1.charAt(left) - 'a';
                    count++;
                    left++;
                    // 左边单词为前缀单词,则该单词数减1
                    if(pre[left_ch] > 0){
                        p[left_ch]--;
                        // 如果当前单词数量减1后不符合前缀条件,则退出循环,进行向右补充单词
                        if(p[left_ch] < pre[left_ch]){
                            len2++;
                            break;
                        }
                    }
                }
                res += ans * count;
            }
        }
        return res;
    }
}
相关推荐
散峰而望3 分钟前
【算法练习】算法练习精选:陶陶摘苹果(基础+升级)、Music Notes、字串变换,你能AC几道?
数据结构·c++·算法·leetcode·贪心算法·github·动态规划
周杰伦fans4 分钟前
C# 异常继承深度解析:从设计原则到 sealed 关键字的奥秘
java·jvm·c#
搬石头的马农4 分钟前
从零配置Claude自动修Bug:6步打造全自动开发流程
java·人工智能·python·bug·ai编程
暗夜猎手-大魔王10 分钟前
转载--Hermes Agent 04 | Agent 主循环:一次对话背后发生了什么
人工智能·python·算法
小马爱打代码12 分钟前
Redis Key 过期后会立刻删除吗?过期删除与内存淘汰策略详解
java·redis·缓存
鱼鳞_19 分钟前
苍穹外卖-Day10(Spring task)
java·后端·spring
雨落在了我的手上27 分钟前
初始java(十七):常⽤⼯具类介绍
java·开发语言
手写码匠34 分钟前
华为云Flexus+DeepSeek征文|基于华为云Flexus X实例 + Dify + DeepSeek 构建企业级智能知识库问答系统实战
人工智能·深度学习·算法·aigc
凤凰院凶涛QAQ38 分钟前
《Java版数据结构 & 集合类剖析》集合框架的封装设计与顺序表:“从 Iterable 到 ArrayList:集合框架的‘职业树“
java·开发语言·数据结构
吴可可1231 小时前
Win7上开发CAD2004自定义实体全解析
c++·算法