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

企业网站管理系统迁安三屏网站建设

企业网站管理系统,迁安三屏网站建设,北京高端定制网站建设,17做网站广州起做网店文章目录 1.问题描述2.难度等级3.热门指数4.解题思路方法一:暴力法方法二:滑动窗口 参考文献 1.问题描述 给定一个字符串 s ,请你找出其中不含有重复字符的最长子串的长度。 s 由英文字母、数字、符号和空格组成。 示例 1: 输…

文章目录

  • 1.问题描述
  • 2.难度等级
  • 3.热门指数
  • 4.解题思路
    • 方法一:暴力法
    • 方法二:滑动窗口
  • 参考文献

1.问题描述

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

s 由英文字母、数字、符号和空格组成。

示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

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

示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。

2.难度等级

Medium。

3.热门指数

★★★★★

出题公司:阿里、腾讯、字节。

4.解题思路

方法一:暴力法

我们可以遍历字符串的所有字符,计算每个字符为起点的不含有重复字符的字串长度,记录到全局变量。

以示例 1 中的字符串 “abcabcbb” 为例,演示暴力法的求解过程。

以 (a)bcabcbb 开始的最长字符串为 (abc)abcbb
以 a(b)cabcbb 开始的最长字符串为 a(bca)bcbb
以 ab(c)abcbb 开始的最长字符串为 ab(cab)cbb
以 abc(a)bcbb 开始的最长字符串为 abc(abc)bb
以 abca(b)cbb 开始的最长字符串为 abca(bc)bb
以 abcab(c)bb 开始的最长字符串为 abcab(cb)b
以 abcabc(b)b 开始的最长字符串为 abcabc(b)b
以 abcabcb(b) 开始的最长字符串为 abcabcb(b)所以最长子串长度为 3。

如何判断重复字符?

常用的数据结构为哈希集合(即 C++ 中的 std::unordered_set,Java 中的 HashSet,Python 中的 set, JavaScript 中的 Set 和 Golang 中的 map 等)。

时间复杂度: O ( n 2 ) O(n^2) O(n2),n 为字符串长度。

空间复杂度: 最好为 O(1),最坏为 O(n)。

方法二:滑动窗口

暴力法的求解过程,实际上存在不必要的检查。

以示例 1 中的字符串 “abcabcbb” 为例,演示暴力法的求解过程可优化的地方。

以 (a)bcabcbb 开始的最长字符串为 (abc)abcbb
以 a(b)cabcbb 开始的最长字符串为 a(bca)bcbb
以 ab(c)abcbb 开始的最长字符串为 ab(cab)cbb
以 abc(a)bcbb 开始的最长字符串为 abc(abc)bb下面这一步是没有必要的,因为以 b 开始的不重复子串 bc 在上一个不重复子串内,长度肯定小于上一个不重复子串。
以 abca(b)cbb 开始的最长字符串为 abca(bc)bb以 abcab(c)bb 开始的最长字符串为 abcab(cb)b同理,下面这一步也是没有必要的。
以 abcabc(b)b 开始的最长字符串为 abcabc(b)b以 abcabcb(b) 开始的最长字符串为 abcabcb(b)

在获取一个子串时,如果遇到了重复字符,那么获取下一个无重复字符的子串时,应该从重复字符的下一个字符开始。

将无重复字符的子串想象成一个滑动窗口,整个求解过程是移动滑动窗口的过程。

如何移动滑动窗口?

当出现重复字符时,我们只要把窗口内重复字符及其左边的元素移出就行了。

一直维持这样的窗口,直至窗口滑动到最后一个字符。记录最长的窗口长度,求出解!

时间复杂度: O(n),n 为字符串长度。

空间复杂度: 最好为 O(1),最坏为 O(n)。

下面以 Golang 为例,给出实现。

func lengthOfLongestSubstring(s string) int {var longest intm := make(map[rune]bool)var left intfor _, c := range s {for m[c] {delete(m, rune(s[left]))left++}m[c] = trueif len(m) > longest {longest = len(m)}}return longest
}

参考文献

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

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

相关文章:

  • 贵州讯玛网站建设wordpress文章表格自适应
  • 微网站建设及微信公众号seo运营工作内容
  • 网站生成word做网站哪个比较好
  • 网站开发惠州windows10优化软件
  • 宁波品牌网站公司排名《网站建设与管理》方案
  • 给一个网站做需求分析网站建设.pdf百度云
  • 网站备案负责人修改武山县建设局网站
  • 网站做微信小程序号码比较好写的电子商务论文题目
  • 上海稼禾建设装饰集团网站有模板了怎么建设网站
  • 信誉好的营销单页网站企业网站备案网地址
  • 网站建设业务方法网上销售有哪些方法
  • 宁波网站关键词推广网站北京备案快吗
  • 厦门做企业网站多少钱网站建设宗旨怎么写
  • 在线手机动画网站模板黄骅港港务集团
  • 网站制作方案设计上海软件公司有哪些
  • 如果用局域网做网站wordpress 个人
  • 定制搭建网站visual studio网页界面设计
  • 有没有免费的简历制作网站网站样版风格排版
  • 元素网站最新网页游戏排行榜2021
  • 网站设计基本要素手工制作小玩具
  • 网站建议反馈应该怎么做丽水网站开发公司电话
  • 山西移动网站设计wordpress备份文件
  • 月嫂云商城网站建设wordpress显示文章时分秒代码
  • 类似聚划算的网站怎么建设免费简历制作
  • 财务公司网站模板wordpress 主题模版
  • 做一手楼盘的网站一级a做爰片免费网站短视频
  • 企业网站主要有哪四种类型企业文化
  • 帮传销做网站温州企业网站制作
  • 昆山建设银行交学费的网站网站建设 中软
  • 怎么注册微网站广西五建公司官网