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

每日算法 -【Swift 算法】不含重复字符的最长子串:暴力解法 vs 滑动窗口

不含重复字符的最长子串:暴力解法 vs 滑动窗口

🧩 题目描述

给定一个字符串 s,请你找出其中不含有重复字符的 最长子串 的长度。

示例

输入: s = "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。输入: s = "bbbbb"
输出: 1
解释: 最长子串是 "b"。输入: s = "pwwkew"
输出: 3
解释: 最长子串是 "wke",注意 "pwke" 是子序列不是子串。

🚫 暴力解法

思路

枚举所有可能的子串,逐个判断是否包含重复字符。

Swift 实现

func lengthOfLongestSubstringBruteForce(_ s: String) -> Int {let chars = Array(s)var maxLength = 0for i in 0..<chars.count {var seen = Set<Character>()var j = iwhile j < chars.count, !seen.contains(chars[j]) {seen.insert(chars[j])j += 1}maxLength = max(maxLength, j - i)}return maxLength
}

时间复杂度

  • 时间:O(n^2),其中 n 是字符串长度。
  • 空间:O(min(n, m))m 是字符集大小(如 ASCII 为 128)。

✅ 滑动窗口解法

思路

使用一个窗口 [left, right] 表示当前无重复字符的子串:

  • right 不断右移扩展窗口
  • 遇到重复字符时,移动 left 缩小窗口

Swift 实现

func lengthOfLongestSubstring(_ s: String) -> Int {var charIndexMap = [Character: Int]()var maxLength = 0var left = 0for (right, char) in s.enumerated() {if let prevIndex = charIndexMap[char], prevIndex >= left {left = prevIndex + 1}charIndexMap[char] = rightmaxLength = max(maxLength, right - left + 1)}return maxLength
}

时间复杂度

  • 时间:O(n),每个字符最多访问两次。
  • 空间:O(min(n, m))

📊 性能对比

解法时间复杂度空间复杂度是否适合大数据量
暴力枚举O(n²)O(min(n, m))❌ 性能低
滑动窗口优化O(n)O(min(n, m))✅ 高效

📌 总结

  • 暴力解法易于理解但性能差,仅适用于小规模数据。
  • 滑动窗口算法利用哈希表快速判断重复字符,大幅提升效率。
  • 本题是滑动窗口技巧的典型应用,适合入门字符串处理优化技巧。

👨‍💻 喜欢这类解题解析?关注我带你继续刷题与优化思路!

http://www.xdnf.cn/news/7458.html

相关文章:

  • Python 实现图片浏览和选择工具
  • 出海跨境电商内容管理难?Baklib 助力打造多语言知识库与智能素材中心
  • Stable Diffusion 学习笔记02
  • 【Nextcloud】使用 LNMP 架构搭建私有云存储:Nextcloud 实战指南
  • TYUT-企业级开发教程-第5章
  • 【C++]string模拟实现
  • laravel 通过Validator::make验证后,如何拿到验证后的值
  • nmcli connection reload
  • C++ qt基类的成员变量,在派生类中需要具有不同的数据类型的解决方法
  • 【NLP】34. 数据专题:如何打造高质量训练数据集
  • 【深度学习基础/面试高频问题】常见的归一化
  • TS01S:单通道差分灵敏度校准电容触摸传感器芯片
  • linux系统双击EXE运行,在统信UOS上无缝运行EXE!统信Windows应用兼容引擎V3来了
  • 模块与包的导入
  • 国产SF2507交换机调试记录
  • 【git进阶】git rebase(变基)
  • 基于RT-Thread的STM32F4开发第五讲——软件模拟I2C
  • 研读论文《Attention Is All You Need》(7)
  • linux安装conda环境-ubuntu
  • linux——mysql故障排查与生产环境优化
  • CSS实现过多的文本进行省略号显示
  • 5:OpenCV—图像亮度、对比度变换
  • MySQL替换瀚高数据库报错: TO_DAYS()不存在(APP)
  • Playwright 多语言一体化——Python_Java_.NET 全栈采集实战
  • oracle序列自增问题
  • 安装NASM
  • 2022年下半年信息系统项目管理师——综合知识真题及答案(4)
  • Tare使用MCP|Win11安装UV
  • 直流电阻和交流电阻区别详解
  • AI大语言模型评测体系演进与未来展望