力扣-字母异位词

这里我也是没有太懂,只懂个大概,先统计p和当前窗口的字符,后主要在窗口大小固定为 p.length(),在 s 上滑动做文章,在s里找到p的长度大小,最后直接比较两个频率数组来判断异位词

定长窗口做法

复制代码
class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        // 存储结果的列表
        List<Integer> ans = new ArrayList<>();
        
        // 创建两个计数器数组,用于统计字符出现频率
        int[] cntP = new int[26]; // 统计字符串 p 的字符频率
        int[] cntS = new int[26]; // 统计 s 的子串的字符频率
        
        // 统计 p 中每个字符的出现次数
        for (char c : p.toCharArray()) {
            cntP[c - 'a']++; // 将字符映射到 0-25 的索引
        }
        
        // 使用滑动窗口遍历字符串 s
        for (int right = 0; right < s.length(); right++) {
            // 将当前字符加入窗口(右边界扩展)
            cntS[s.charAt(right) - 'a']++;
            
            // 计算当前窗口的左边界
            int left = right - p.length() + 1;
            
            // 如果窗口长度不足 p.length(),跳过后续处理
            if (left < 0) {
                continue;
            }
            
            // 检查当前窗口是否是 p 的异位词
            if (Arrays.equals(cntS, cntP)) {
                ans.add(left); // 如果是,记录起始索引
            }
            
            // 将左边界字符移出窗口(为下一次窗口滑动做准备)
            cntS[s.charAt(left) - 'a']--;
        }
        
        return ans;
    }
}
相关推荐
铉铉这波能秀2 分钟前
正则表达式从入门到精通(字符串模式匹配)
java·数据库·python·sql·正则表达式·模式匹配·表格处理
Liangwei Lin4 分钟前
洛谷 P10471 最大异或对 The XOR Largest Pair
算法
sin_hielo5 分钟前
leetcode 3652(定长滑动窗口/前缀和)
数据结构·算法·leetcode
AI科技星5 分钟前
质量定义方程中条数概念的解析与经典例子计算
数据结构·人工智能·经验分享·算法·计算机视觉
啊阿狸不会拉杆6 分钟前
《数字图像处理》第8章-图像压缩和水印
图像处理·人工智能·算法·计算机视觉·数字图像处理
智航GIS7 分钟前
ArcGIS大师之路500技---034重采样算法选择
人工智能·算法·arcgis
子夜江寒7 分钟前
决策树与回归树简介:原理、实现与应用
算法·决策树·回归
TL滕11 分钟前
从0开始学算法——第十九天(并查集)
笔记·学习·算法
武子康11 分钟前
Java-202 RabbitMQ 生产安装与容器快速启动:Erlang 兼容、RPM 部署与常用命令
java·消息队列·rabbitmq·erlang·java-rabbitmq·mq
Swift社区13 分钟前
LeetCode 451 - 根据字符出现频率排序
算法·leetcode·ssh