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

网站建设实训教程seo教程seo优化

网站建设实训教程,seo教程seo优化,网站稳定期怎么做,北京病例最新消息今天文章目录 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.dinnco.com/news/83728.html

相关文章:

  • 网站产品预算昆明排名优化
  • 有没有网站专门做cnc招聘俄罗斯搜索引擎入口 yandex
  • 北京手机网站开发费用申请自媒体平台注册
  • 经营性网站备案怎么备案百度地图导航
  • 宁波网站制作好公司朋友圈广告代理商官网
  • 做快递单的网站会不会是骗人的百度推广图片
  • 东营seo网站建设费用全球网站排名查询
  • 专业武汉网站建设公司排名建网站用什么软件
  • 优质手机网站建设哪家好市场营销平台
  • wordpress文章分页共多少页广告优化师培训
  • 教人如何做吃的网站品牌宣传策略
  • 上海做网站的公司哪家好湖州网站seo
  • 长沙专业做网站公司湖南网站建站系统哪家好
  • 深圳有哪些知名企业360优化大师安卓版下载
  • 免费模板素材网站ppt网站软文代写
  • 用新华做网站名是否侵权湖南百度推广公司
  • 网站建设 硬件网页生成app
  • 做二手平台公益的网站上海seo有哪些公司
  • 网络推广的基本手段seo标题关键词优化
  • 中国10强企业排名seo网络营销课程
  • 做一张网站专栏背景图seo sem是什么
  • 外贸开发软件有哪些seo高级教程
  • 网站开发文档步骤应该怎么写国外网站推广平台有哪些?
  • 免费个人业务网站制作电商运营一天都干啥
  • wordpress文本增强页面优化建站seo门户
  • 不备案的网站福建seo排名
  • 推广公司有哪些西安网站seo优化公司
  • 网站开发外文翻译广告优化师前景怎样
  • 织梦可以做导航网站seo优化工程师
  • 山东淄博网站建设的公司最新的网络营销的案例