76. Minimum Window Substring【力扣】

本文探讨了如何在字符串S中找到包含字符串T所有字符的最小子串,允许字符顺序颠倒。通过分析滑动窗口和哈希表的方法,文章详细解释了双指针法的优化技巧,包括在一次循环中同时处理左右指针,减少搜索范围,并避免保存所有可能的子串。此外,还提到了使用哈希映射来快速比较字符串包含关系。最后,提供了问题的解决方案链接供进一步阅读。
摘要由CSDN通过智能技术生成

题意理解

给定一个字符串T,问在另一个字符串S中包含这个字符串的字符的最小长度子字符串。字符顺序可以颠倒

问题分析

滑动窗口 + hashtable做 (双指针法)

其他

比较字符串是否包含,可以用hashmap或字典(每个字符占一个元素位置),字典的速度比map要快

我的方法耗时太长,这里有O(n)的算法。慢慢看。

https://leetcode.com/problems/minimum-window-substring/discuss/26840/Sharing-my-straightforward-O(n)-solution-with-explanation

看完了。几个优化点

一次循环中,同时处理扩展右下标和缩小左下标。

两个map的比较,我是直接找到了全部的t字符再比较,这个方法是逐步删除了左边不满足的字符来比较。搜索的范围小了很多。

不用把所有合适的都保存下来,再从中找最小的那个,而是每次找到一个新字符串,就更新最小的字符串。

每次都是把字符串取下来,再传入函数和t的map比较,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值