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

网站制作过程内容网站建设 开票

网站制作过程内容,网站建设 开票,盐津铺子网络营销推广方法,嘉兴网站备案LeetCode 3:寻找最长不含重复字符的子串长度 在字符串处理中,寻找最长不含重复字符的子串长度是一个经典问题。 问题描述 给定一个字符串 s ,我们需要找出其中不含有重复字符的最长子串的长度。 解决方案 我们可以使用滑动窗口的方法来解…

LeetCode 3:寻找最长不含重复字符的子串长度

在字符串处理中,寻找最长不含重复字符的子串长度是一个经典问题。

问题描述

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

解决方案

我们可以使用滑动窗口的方法来解决这个问题。滑动窗口是一个区间,它可以通过两个指针来表示。在这个问题中,我们使用两个指针表示子串的左右边界。

我们使用一个哈希集合(unordered_set)来存储当前窗口中的字符,以便快速检查一个字符是否已经在当前窗口中。同时,我们使用两个指针 lefti 来表示当前窗口的左右边界,初始时都指向字符串的开头。

接下来,我们遍历字符串 s,对于每个字符,我们做如下操作:

  1. 如果当前字符已经在窗口中存在,我们需要将左指针 left 移动到当前重复字符的下一个位置,以保证窗口中没有重复字符。
  2. 更新窗口中的字符集合,即将当前字符加入到集合中。
  3. 更新最长不含重复字符的子串的长度。

最终,我们返回最长子串的长度。

代码实现

class Solution {
public:int lengthOfLongestSubstring(string s) {if(s.size() == 0) return 0;   // 如果字符串长度为0直接返回unordered_set<char> set;int maxStr = 0;int left = 0;for(int i = 0; i < s.length(); i++) {while(set.find(s[i]) != set.end()) {set.erase(s[left]);left++;}set.insert(s[i]);maxStr = max(maxStr, i - left + 1);}return maxStr;}
};

示例

让我们通过一个示例来说明上述算法的工作方式:

假设输入字符串为 "abcabcbb",那么算法将按以下步骤执行:

  • 遍历字符串,初始时 left = 0, maxStr = 0
  • i = 0 时,字符 a 不在集合中,加入集合,更新 maxStr = max(maxStr, i - left + 1) = 1
  • i = 1 时,字符 b 不在集合中,加入集合,更新 maxStr = max(maxStr, i - left + 1) = 2
  • i = 2 时,字符 c 不在集合中,加入集合,更新 maxStr = max(maxStr, i - left + 1) = 3
  • i = 3 时,字符 a 在集合中,移动 left 指针到下一个位置,更新 left = 1
  • 以此类推,直到遍历完整个字符串。

最终,返回 maxStr = 3,表示最长不含重复字符的子串长度为3。
对于给定字符串 s 的长度为 n,我们的算法使用了滑动窗口来寻找最长不含重复字符的子串长度。

复杂度分析

时间复杂度分析

  • 遍历字符串: 算法需要遍历一次输入字符串 s,时间复杂度为 O(n),其中 n 是字符串的长度。
  • 滑动窗口操作: 在滑动窗口操作中,我们最多移动左指针 left 和右指针 i 各一次。对于每个字符,我们在常数时间内检查是否在集合中,因此滑动窗口操作的时间复杂度为 O(1)。
  • 因此,总体时间复杂度为 O(n)。

空间复杂度分析

  • 哈希集合: 我们使用了一个哈希集合来存储当前窗口中的字符。在最坏情况下,集合中可能包含字符串中的所有字符,因此空间复杂度为 O(min(n, m)),其中 n 是字符串的长度,m 是字符集的大小(ASCII 字符集为 256)。
  • 其他变量: 我们使用了常数个额外的变量,因此空间复杂度为 O(1)。

总结

通过滑动窗口的方法,我们可以在时间复杂度为 O(n) 的情况下解决这个问题。该方法利用了哈希集合的快速查找特性,使得算法具有高效性能和较好的扩展性,适用于处理大规模的字符串输入。

http://www.yayakq.cn/news/548449/

相关文章:

  • 网站后台用什么开发大型网站建设用什么系统好
  • 外包类设计网站1免费做网站
  • 成华区统一建设办公室网站elo机制
  • 现在网站的外部链接怎么做手机网站设计创意说明
  • 那个网站做毕业设计谷歌推广服务
  • 北京网站开发要多少钱搜索app下载安装
  • 徐州cms建站系统福永营销型网站多少钱
  • 李炎辉网站建设教程app外包公司有哪些
  • 音乐网站开发开发重庆市建设工程造价站
  • wordpress好看的底部深圳做网站可用乐云seo十年
  • ip地址进入网站怎么做的软件开发一般用什么软件
  • 大气集团网站互联网行业 英文
  • 郑州个人做网站有没有资源免费的
  • 订餐网站系统建设方案logo在线制作免费生成
  • 网站建设什么因素最重要网站跳转代码 html
  • 购物网站 建设 费用寻花问柳-专注做一家男人的网站猪
  • 网站开发 前端 后端助农网站策划书
  • 公司网站建设的项目工作分解结构中小微企业网站建设
  • 查公司备案网站备案广东深圳房价
  • 网站留言发送到邮箱网站建设的一些销售技巧
  • 买一个成品网站多少钱wordpress切换背景
  • 昆明本地网站xampp wordpress 安装教程
  • 郑州企业建站模板上海闵行区房价
  • 网站后台模板怎样使用大型网站开发用什么技术
  • 建设通招标网站软件下载网站排行榜前十名
  • 金银回收东莞网站建设交互式网站备案难吗
  • 北京住总第一开发建设有限公司网站小学学校网站建设计划
  • 个人网站的设计与开发建设公司网站要注意什么
  • 网站建设的cms系统如何建设微信网站
  • 广东网站建设费用如何做网站推广的策略