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

LeetCode 3.无重复字符的最长子串

3.无重复字符的最长子串

题面:

给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。
【字串】:子字符串 是字符串中连续的 非空 字符序列。

示例 1:

输入: s = “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。注意 “bca” 和 “cab” 也是正确答案。
示例 2:

输入: s = “bbbbb”
输出: 1
解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。
示例 3:

输入: s = “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。
请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。

解析:
复杂度

时间复杂度O ( n ) O(n)O(n)
空间复杂度O ( m i n ( n , m ) ) ( m 为字符集大小) O(min(n, m))\ (m为字符集大小)O(min(n,m))m为字符集大小)

Code
// C++ class Solution { public: int lengthOfLongestSubstring(string s) { unordered_set<char> temp; int left = 0; int right = 0; int ans = 0; int n = s.size(); while (right < n) { auto it = temp.find(s[right]); if (it == temp.end()) // 当前set中不存在该字符记录 { temp.insert(s[right]); right++; ans = max(ans, right - left); } else { temp.erase(s[left]); left++; } } return ans; } };
# PythonclassSolution:deflengthOfLongestSubstring(self,s:str)->int:temp=set()n=len(s)left,right,ans=0,0,0whileright<n:ifs[right]notintemp:temp.add(s[right])right+=1ans=max(ans,right-left)else:temp.remove(s[left])left+=1returnans
// Rust// use std::cmp;usestd::collections::HashSet;implSolution{pubfnlength_of_longest_substring(s:String)->i32{letmuttemp=HashSet::new();letmutleft=0;letmutright=0;letmutans=0;letn=s.len();// Rust无法直接通过索引访问字符,需要转化为Vec<char>letchars:Vec<char>=s.chars().collect();whileright<n{if!temp.contains(&chars[right]){temp.insert(chars[right]);right+=1;// ans = cmp::max(ans, right - left);ans=ans.max(right-left);}else{temp.remove(&chars[left]);left+=1;}}ansasi32}}
http://www.cnnetsun.cn/news/150032.html

相关文章:

  • 如何高效配置TPC1570Gi工控机?McgsPro v3.2.3完整操作指南
  • 终极指南:深度解析RAF-DB人脸表情识别数据集
  • 如何快速制作专业简历:计算机保研学生的终极指南
  • 如何快速构建机器学习开发环境:面向数据科学家的终极指南
  • 13、深入理解与管理Windows组策略
  • 14、集中式桌面的组策略管理指南
  • 21、Windows Server 2012磁盘管理全攻略
  • 27、DNS管理与TCP/IP故障排除全解析
  • 32、虚拟机器维护与性能调优全攻略
  • 微服务智能降级防护:Kratos自适应策略的双重保险机制
  • 终极指南:使用Bucket4j轻松实现Java应用速率限制
  • 英文文献在哪里找:高效查找英文文献的实用方法与资源推荐
  • FaceFusion能否实现动物脸部替换?猫狗换脸实验记录
  • 2025终极方案:用google-api-php-client实现智能SEO监控系统
  • UMD架构深度解析:跨环境模块定义的设计原理与演进路径
  • 5大高效策略:利用Blockly调试工具彻底解决Python代码生成难题
  • 5分钟打造个性化浏览器主页:Bonjourr极简体验全攻略
  • 三大扩散Transformer架构深度对比:DiT、SiT、FiT性能全面评测
  • Material Files:Android上最优雅的开源文件管理器终极指南 [特殊字符]️
  • css样式attr()获取元素属性值测试
  • Lottie-Android文本动画终极指南:从静态文字到动态交互体验
  • 信息系统项目管理师报考指南(长图版)
  • FaceFusion与DaVinci Resolve的整合方案构想
  • FaceFusion如何应对对抗样本攻击?安全机制解析
  • GB Studio资源导入全流程解析:从新手到高手的格式选择指南 [特殊字符]
  • 一键部署FaceFusion镜像,快速实现专业级人脸交换
  • FaceFusion镜像企业定制版服务正式启动
  • LSPlant框架深度解析:构建Android系统级HOOK引擎的完整指南
  • Windows 11离线环境.NET Framework 3.5完整安装指南
  • 错过后悔一年!双十一必买的Open-AutoGLM智能推荐清单(限量版曝光)