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

示例 1:

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

示例 2:

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

示例 3:

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters

分析:

这三种方法都是属于广义上的滑动窗口法,只是采用的数据结构以及一些操作有所不同

方法一:采用set判断子串中是否存在该字符

暴力的复杂度在于判断一个字串里面是否存在该字符,需要遍历子串,导致暴力的时间复杂度为O(N^2),判断一个字符是否存在于子串中可以采用set集合判断,这样子串中判断字符是否存在的时间复杂度为O(1)

时间复杂度:O(2*N)=O(N),在最糟糕的情况下,每个字符将被 i 和 j访问两次。

空间复杂度: set的大小取决于字符串长度n和字符集的大小m,所以空间复杂度O(min(n,m))

class Solution {
public:
int lengthOfLongestSubstring(string str)
{if(str=="")return 0;set<char> ss;int i=0,j=0,n=str.length();int ans=-1;while(i<n&&j<n){if(ss.find(str[j])==ss.end()){ss.insert(str[j++]);ans=max(ans,j-i);}else{ss.erase(str[i++]);}}return ans;
}
};

执行时间:60 ms

方法二:采用map或者数组存储每个字符最后出现的索引位置,以便i跳跃式前进

在S[i]到S[j]内如果有字符s[k]重复于S[j+1]的话,如果采用set,i是逐渐增加的(每次前移1位),但是如果采用map存储每个字符最后出现的索引位置,这样i可以直接跳到k+1,属于跳跃式前进

字符集大小:m

时间复杂度:O(2*N)=O(N)

空间复杂度:O(m)

class Solution {
public:
int lengthOfLongestSubstring(string str)
{if(str=="")return 0;map<char,int> mm;int i=0,j=0,n=str.length();int ans=-1;for(i=0,j=0;j<n;j++){if(mm.find(str[j])!=mm.end()){i=max(i,mm[str[j]]);}ans=max(ans,j-i+1);mm[str[j]]=j+1;}return ans;
}
};

执行时间:32 ms

 

方法三:采用数组存储字符索引,start代表没有重复子串的开头

如果原来出现过的字符的位置大于start,那么更新start

i-start=没有重复子串的长度

该方法省去了在子串中利用map或者set查找是否存在某字符的操作,直接判断一下当前字符出现过的最后位置是否大于start

时间复杂度:O(N)

空间复杂度:O(m),m为字符集的大小

class Solution
{
public:int lengthOfLongestSubstring(string str){vector<int> v(300,-1);int ans=0;int n=str.length();int start=-1;for(int i=0; i<n; i++){if(v[str[i]]>start){start=v[str[i]];}v[str[i]]=i;ans=max(ans,i-start);}return ans;}
};

执行时间:8 ms

 

滑动窗口展示的动态图片请参考:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/solution/hua-jie-suan-fa-3-wu-zhong-fu-zi-fu-de-zui-chang-z/

转载于:https://www.cnblogs.com/yinbiao/p/11271893.html

【LeetCode】无重复字符的最长子串【滑动窗口法】相关推荐

  1. LeetCode精讲 03无重复字符的最长子串(滑动窗口)

    题目描述 原创作者:bigsai,维护不易,如有收获,还请点赞.收藏支持! 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcb ...

  2. LeetCode 3. 无重复字符的最长子串 (滑动窗口哈希表)

    3. 无重复字符的最长子串 题意: 找子串 子串中无重复字符 要求子串长度最长 解法1(暴力法) 思路: 建立一个长度不断变小的滑动窗口 用一个指针指针扫描窗口内的每个元素: 如果除去指针指向的那个元 ...

  3. Leetcode刷题100天—3. 无重复字符的最长子串(滑动窗口+集合+双指针)—day21

    前言: 作者:神的孩子在歌唱 大家好,我叫运智 3. 无重复字符的最长子串 难度中等6009收藏分享切换为英文接收动态反馈 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度. 示例 ...

  4. python最长连续子串_LeetCode 03无重复字符的最长子串(滑动窗口)

    关注.在看,回复进群打卡 题目描述 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为 ...

  5. python学习3. 无重复字符的最长子串(滑动窗口)

    makcooo 2019-04-19 15:47:32  271  收藏 分类专栏: python 版权 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: &quo ...

  6. JAVA窗口sin值_大厂经典笔试题—LeetCode03无重复字符的最长子串(滑动窗口)

    题目描述 原创作者:bigsai,长期维护不易,如有收获还请点赞.收藏支持! 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabc ...

  7. leetcode 无重复字符的最长子串

    给定一个字符串,找出不含有重复字符的最长子串的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 无重复字符的最长子串是 "abc",其长度为 ...

  8. 无重复字符的最长子串php,LeetCode - 无重复字符的最长子串 - Golang

    题目:给定一个字符串,请你找出其中不含有重复字符的 最长子串的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 `"abc ...

  9. 学渣的刷题之旅 leetcode刷题 3. 无重复字符的最长子串(暴力法、滑动窗口)

    给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc&qu ...

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

    给定一个字符串 s ,请你找出其中不含有重复字符的最长子串的长度. 示例一: 示例二: 示例三: 思路分析: 首先定义一个Set集合存储多个字符,同时定义一个右指针rk=-1,外层套一个循环定义左指针 ...

最新文章

  1. 配置ISA Server 2006 ×××使用户轻松连接内网
  2. centos mysql-5.5.20_centos 下安装mysql5.5.20出现的问题
  3. vue+vant 移动端H5 商城项目_01
  4. MySQL INSERT ... ON DUPLICATE KEY UPDATE语句
  5. idea项目工程里面自动生成的.iml文件无法删除的解决方法
  6. Zynq7000硬件开发之硬件开发流程简介(二)
  7. 模拟爬虫下载QQ空间相册高清图片
  8. 从零开始做运营第一课:运营是做什么的?一篇文章解释清楚!
  9. 名编辑电子杂志大师教程 | 仿古书翻页
  10. DBN深度信念网络详解
  11. 一篇文章入门Spring
  12. 春考计算机专业PS考点,春考辅导:春考PS的学习方法和技巧
  13. 如何抠图人像换背景?教你一个在线操作的方法
  14. javaScript-模块化开发
  15. 惨烈!2018年这些企业“阵亡”了…
  16. 中国到底有多少个程序员?都在哪个城市写代码?
  17. 使用nid修改dbname和dbid
  18. go语言进行web开发之安装iris框架
  19. Autosar BSW层CAN通讯开发------08(Autosar的E2E开发-----以E2E Profile01为例)
  20. 计算机语言a什么码,a的ascll码是什么意思

热门文章

  1. Netty系列之Netty 服务端创建
  2. PHPCMS V9 框架代码分析(入口程序)
  3. Sticker.js生成图片或者页面元素“速干贴”效果
  4. WCF 第四章 绑定 绑定元素
  5. [导入]关于怎样通过xslt向.NET扩展函数传递OuterXml属性
  6. 4.1 df命令 4.2 du命令 4.3/4.4 磁盘分区
  7. 【单页应用】全局控制器app应该干些什么?
  8. APUE-文件和目录(二)函数access,mask,chmod和粘着位
  9. 数据库中char与varchar类型的区别
  10. java中处理字符编码(网页与数据库)(转)