当前位置: 首页 > news >正文

【算法】滑动窗口—找所有字母异位词

         “找到字符串中所有字母异位词”的难度为Medium,看一下题目:

        给定一个字符串 S 和一个非空字符串 T,找到 S 中所有是 T 的字母异位词的子串,返回这些子串的起始索引。

        所谓的字母异位词,其实就是全排列,原题目相当于让你找 S 中所有 T 的排列,并返回它们

的起始索引。

        比如输入 S = "cbaebabacd",T = "abc",算法返回 [0,6],因为 S 中有两个子串 "cba" 和 "bac" 是 T 的排列,它们的起始索引是0和6。

        直接套模板(看专栏)写代码:

package SlidingWindow;import java.util.*;// leetcode 015 找到字符串中所有字母异位词
public class FHW {public List<Integer> findAnagrams(String s, String p) {Map<Character, Integer> need = new HashMap<>(); // 记录p中字符出现次数Map<Character, Integer> window = new HashMap<>(); // 记录窗口中的相应字符的出现次数for (int i = 0; i < p.length(); i++) {char key = p.charAt(i);need.put(key, need.getOrDefault(key, 0) + 1);}int left = 0, right = 0, valid = 0; // valid 表示窗口中满足 need 条件的字符个数List<Integer> res = new ArrayList<>();while (right < s.length()) {// c 是将要移入窗口的字符char c = s.charAt(right);// 右移窗口right++;// 进行窗口内数据的一系列更新if (need.containsKey(c)) {window.put(c, window.getOrDefault(c, 0) + 1);if (window.getOrDefault(c, 0).equals(need.getOrDefault(c, 0))) { // window[c] == need[c]valid++;}}/*** debug 输出的位置***/System.out.println("window:(" + left + ", " + right + ")");/*********************/// 判断左侧窗口是否要收缩while (right - left >= p.length()) { // window need shrink —窗口需要收缩// 当窗口符合条件时,把起始索引加入 resif (valid == need.size()) {res.add(left);}// d 是将要移出窗口的字符char d = s.charAt(left);// 左移窗口left++;// 进行窗口内数据的一系列更新if (need.containsKey(d)) {if (window.getOrDefault(d, 0).equals(need.getOrDefault(d, 0))) {valid--;}window.put(d, window.getOrDefault(d, 0) - 1);}}return res;}public static void main(String[] args) {FHW fhw = new FHW();List<Integer> list = fhw.findAnagrams("abab","ab");System.out.println(list);}}

        和寻找字符串的排列一样,只是找到一个合法异位词(排列)之后将起始索引加入 res 即可。

http://www.lryc.cn/news/438320.html

相关文章:

  • Vue安装及环境配置【图解版】
  • 绕过CDN查找真实IP方法
  • Qt与MQTT交互通信
  • dd 命令:复制和转换文件
  • 文件系统(磁盘 磁盘文件 inode)
  • ThreeJs创建圆环
  • React实现类似Vue的路由监听Hook
  • Visual Studio打开项目的一些小技巧
  • 前端页面中使用 ppt 功能,并且可以随意插入关键帧
  • 机器学习:opencv--图像金字塔
  • linux安全软件Hydra使用教程
  • 【ShuQiHere】从晶体管到逻辑门:数字电路的构建之旅
  • PDF扫描版文字识别OCR
  • Synchronized由什么样的缺陷? Java Lock是怎么弥补这些缺陷的?
  • 联合仿真(FMI,FMU)资料收集
  • Android Radio2.0——动态列表回调(七)
  • 在conda虚拟环境中安装cv2(试错多次总结)
  • 【EI稳定,马来亚大学主办】2024年计算机与信息安全国际会议(WCCIS 2024,9月27-29)
  • 免费AI播客生成:notebooklm可以生成播客的两个发言人谈论的内容,从各种来源如研究论文、文章
  • “MIME 媒体类型“用来标识网络传输内容的格式标准
  • MySql的基础讲解
  • 类型转换等 面试真题
  • MySQL下载安装
  • golang实现正向代理http_proxy和https_proxy
  • 数字IC设计\FPGA 职位经典笔试面试--整理
  • Golang协程泄漏定位和排查
  • 【我的 PWN 学习手札】Unlink Attack
  • 算法笔试-编程练习-好题-04
  • 使用Rustup快速无缝升级Rust
  • pytorch qwen2-vl自定义数据全量微调