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

76.最小覆盖子串

给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串,则返回空字符串 “” 。
注意:
对于 t 中重复字符,我们寻找的子字符串中该字符数量必须不少于 t 中该字符数量。
如果 s 中存在这样的子串,我们保证它是唯一的答案。

class Solution {public String minWindow(String s, String t) {String minstr = "";Map<Character,Integer> need = new HashMap<>();Map<Character,Integer> win = new HashMap<>();for(char c : t.toCharArray()){need.put(c,need.getOrDefault(c,0)+1);}int left = 0, right = 0, tagl = 0;int size = 0, minLen = Integer.MAX_VALUE;while(right < s.length()){char cr = s.charAt(right);right++;if(need.containsKey(cr)){win.put(cr,win.getOrDefault(cr,0)+1);//这里使用==就会有bugif(win.get(cr).equals(need.get(cr))){size++;}}while(size == need.size()){//因为right已经+1了if(right - left < minLen){minLen = right - left;tagl = left;}char cl = s.charAt(left);left++;if(need.containsKey(cl)){//这里使用==就会有bugif(win.get(cl).equals(need.get(cl)))size--;win.put(cl,win.get(cl)-1);}}}return minLen == Integer.MAX_VALUE ? "":s.substring(tagl,tagl+minLen);}
}
http://www.lryc.cn/news/378817.html

相关文章:

  • 深度学习算法informer(时序预测)(三)(Encoder)
  • HTML和CSS基础(一)
  • 低代码平台教你两步把SQL直接转换为RESTful API
  • JavaWeb阶段学习知识点(二)
  • 数据结构【二叉树】
  • Vue P17-54
  • 【自动驾驶】从零开始做自动驾驶小车
  • 一文让你彻底搞懂什么是VR、AR、AV、MR
  • Python设计模式 - 简单工厂模式
  • L55--- 257.二叉树的所有路径(深搜)---Java版
  • 智慧园区解决方案PPT(53页)
  • Windows安装MySQL(8.0.37)
  • 永磁同步电机驱动死区补偿
  • 智能体合集
  • 智能农业管理系统设计
  • Matlab的Simulink系统仿真(simulink调用m函数)
  • C语言中操作符详解(一)
  • 【论文阅读】Multi-Camera Unified Pre-Training via 3D Scene Reconstruction
  • 深入了解NumPy的原理与使用
  • Linux Centos 环境下搭建RocketMq集群(双主双从)
  • 全网最全postman接口测试教程和项目实战~从入门到精通
  • 【ARM】MDK Debug模式下Disassembly窗口介绍
  • 灵活的招聘管理系统有五种方法帮助成功招聘
  • 美摄科技匿名化处理解决方案,包含模糊、同色、马赛克、效果遮挡等各种形式
  • O2OA的数据库数据库配置-使用不同用户访问Oracle时报错-表或视图不存在
  • leetcode56 合并区间
  • Elasticsearch扩展性探索:水平扩展与集群管理
  • node版本过高出现ERR_OSSL_EVP_UNSUPPORTED错误
  • 不得不看的AI前沿理论与技术: LLM-Assisted Light大模型
  • 流行跨链桥总结