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

上海影城改造升级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.yayakq.cn/news/321708/

相关文章:

  • 山西做网站如何选择宁波怎么建网站模板站
  • 建材做网站好吗素材大全
  • 网站开发那种语言好wordpress添加轮播图
  • 网页模板网站模板wordpress 小程序
  • 个人做门户网站重庆装修公司哪家好
  • 网站统计怎么做夸克搜索网页版
  • 大良网站智能推广机构免流网站开发
  • 海门网站开发易语言如何做验证系统官方网站
  • 网站建设seo优化内蒙低成本门户网站开发
  • 网站建设 检查 通报建设银行短信带网站
  • 定制网站建设流程旅游网站开发意义和背景
  • 做美食网站的优势wordpress在线更新
  • dede网站打开慢做涂鸦的网站
  • 网站源码整站打包wordpress 首页显示分类文章列表
  • 潜江网站开发软件开发外包
  • 大学生网站建设策划书范文wordpress 图书模板
  • 驻马店北京网站建设做外贸的社交网站
  • 威海相亲网站网站服务器的工作原理
  • 建设网站分几个步骤现在建网站多少钱
  • 可以用AI做网站上的图吗杭州网站建设zj net
  • 做公众号首图的设计网站网站名称跟域名
  • 使用腾讯云建设网站工业软件有哪些
  • 免费个人网站建站申请推广网页
  • 昆山网站建设苦瓜做网站的范本
  • 百度做网站的特点定制开发app软件
  • 网站怎么做推广和优化wordpress 站点群
  • 网站怎么做移动图片wordpress首页显示vip标志
  • 做视频网站免费观看爱山东app网站制作
  • 企业网站的建设与实现论文网站维护员
  • 青海格尔木建设局网站网游大全