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

【Swift】LeetCode 76. 最小覆盖子串

76. 最小覆盖子串

在这里插入图片描述

题目描述

请添加图片描述

思路 and Swift 题解

这道题目是一道比较复杂的滑动窗口题目。

解决这道题目的思路是,针对st,开两个 Dictionary,类型是[Character: Int],分别记录s子串当中出现过字符的数量以及字符串t当中字符出现过的数量,命名为msmt。然后,针对字符串s,维护一个从左到右子串的滑动窗口,在窗口当中比较mt当中出现过的字符的数量是否小于等于ms当中相应字符出现过的数量(以mt的 Key 作为ms的 Key,比较二者 Value 的大小)。如果满足mt当中出现过的字符都在当前ms字典当中,且ms当中字符出现过的数量≥\geqmt当中字符出现过的数量,就说明当前的窗口满足条件,设置startminLen来记录当前窗口的起始点与长度。

再然后,我们就需要对窗口进行缩小,也就是调整左边界。如果以上条件持续满足,那么取左边界的字符,将其出现过的次数从ms当中删除一次。如果仍然满足,则持续上述行为,并相应调整startminLen;如果不满足,则继续向右滑动窗口,寻找下一次可能的答案。

最后,如果ms当中的一个窗口满足了题意,那么返回这个窗口对应的子串;否则返回空字符串。可以设置初始时var minLen = s.count + 1,如果滑动窗口维护结束时minLen仍然是s.count + 1,就说明s当中没有满足题意的子串,返回空字符串。

上面的思路是没问题的,但存在的一个问题就是,每一次维护滑动窗口左边界时,都需要完全比对一次msmt两个字典,时间复杂度非常高。一个优化的思路是,我们不在每次维护左边界时比对两个字典,而是维护一个名为valid的整型变量,它的初始值为0,作用就是记录当前滑动窗口当中多少个在p当中出现过的字符的数量与在滑动窗口当中出现的相应字符的数量相同。如果valid == mt.count,就说明当前的滑动窗口满足题意,开始对左边界进行维护。维护左边界left时,需要相应地调整valid的值,如果ms[s[left]] == mt[s[left]],由于此时需要将s[left]从滑动窗口当中删除,导致ms[s[left]] != mt[s[left]],因此需要valid -= 1

完整的 Swift 题解:

class Solution {func minWindow(_ s: String, _ t: String) -> String {guard !s.isEmpty && !t.isEmpty else {return ""}var s = Array(s), t = Array(t)var ms = [Character: Int](), mt = [Character: Int]()for i in 0..<t.count {mt[t[i], default: 0] += 1}var left = 0, right = 0, valid = 0, start = 0, minLen = s.count + 1while right < s.count {var c = s[right]right += 1if mt[c] != nil {ms[c, default: 0] += 1if ms[c] == mt[c] {valid += 1}}while valid == mt.count {// 如果已经 t 当中字符出现的数量已经与 s 的子串当中相应字符出现的数量相同, 就开始收缩左边界var currLen = right - leftif currLen < minLen {start = leftminLen = currLen}var d = s[left]left += 1if mt[d] != nil {if ms[d] == mt[d] {valid -= 1}ms[d]! -= 1}}}return minLen == s.count + 1 ? "" : String(s[start..<(start + minLen)])}
}
http://www.dtcms.com/a/561327.html

相关文章:

  • 网站优化哪家专业工厂关键词网络推广
  • 颍泉网站建设写一个网站
  • 视觉Transformer的介绍即ViT模型的搭建(pytorch版本)
  • Python企业编码规范
  • 电力电子技术 第十二章——方波逆变器
  • 网站后台 模板商业网站建设案例课程百度云
  • 从零开始学网站建设新农村建设投诉在哪个网站
  • FastAPI使用详解
  • idmd设计邯郸整站优化
  • MIT-两个多项式相乘
  • 【每天一个AI小知识】:什么是AI Agent?
  • 547.力扣LeetCode_ 省份数量
  • Python编程实战—面向对象与进阶语法 | 属性与方法
  • 县级林业网站建设管理河南省住房和城乡建设厅电话
  • 自己怎么做返利网站中国做陶壶的网站有哪些
  • C++11新特性介绍
  • 软考 系统架构设计师系列知识点之杂项集萃(187)
  • 好用百度seo排名优化软件工具(seo快速优化软件)
  • 【SSM框架 | day24 spring IOC 与 DI】
  • .net 8.0 System.InvalidOperationException:“Session has not been configured
  • 网站关键词排名快速提升网站域名空间续费合同
  • 本地大模型、本地embeding、本地数据库、本地RAG Flow搭建方式——从显卡驱动开始
  • 10-神经网络的工作原理:分析神经网络如何学习和推理
  • 无锡做网站的公司网站业务员怎么给客户做方案
  • HarmonyOS Divider组件深度定制:从基础分割到高级视觉表达
  • 外包公司做的网站怎么改密码光辉网络 石家庄网站建设
  • 一道面试高频题:如何判断完全二叉树?
  • 使用Stream API重构你的数据处理
  • ps做网站首页怎么广州公共资源交易
  • discuz 门户网站模板物联网今天正式开网