【LeetCode】无重复字符的最长子串【滑动窗口法】
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例 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 ;
set<char> ss;
int i=,j=,n=str.length();
int ans=-;
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 ;
map<char,int> mm;
int i=,j=,n=str.length();
int ans=-;
for(i=,j=;j<n;j++)
{
if(mm.find(str[j])!=mm.end())
{
i=max(i,mm[str[j]]);
}
ans=max(ans,j-i+);
mm[str[j]]=j+;
}
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(,-);
int ans=;
int n=str.length();
int start=-;
for(int i=; 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
【LeetCode】无重复字符的最长子串【滑动窗口法】的更多相关文章
- [LeetCode]3. 无重复字符的最长子串(滑动窗口)
题目 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc ...
- leetcode的Hot100系列--3. 无重复字符的最长子串--滑动窗口
可以先想下这两个问题: 1.怎样使用滑动窗口? 2.如何快速的解决字符查重问题? 滑动窗口 可以想象一下有两个指针,一个叫begin,一个叫now 这两个指针就指定了当前正在比较无重复的字符串,当再往 ...
- [LeetCode]无重复字符的最长子串
给定一个字符串,找出不含有重复字符的最长子串的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 无重复字符的最长子串是 "abc",其长度为 ...
- leetcode无重复字符的最长子串
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc&qu ...
- LeetCode 无重复字符的最长子串(探索字节跳动)
题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "a ...
- leetcode 无重复字符的最长子串 python实现
这道题需要借助哈希查找key的O(n) 时间复杂度, 否则就会超时 初始化一个 哈希表\字典 dic 头指针start 初始为0 当前指针 cur 初始为0 最大长度变量 l 初始为0 用cur变量 ...
- Leetcode(三)无重复字符的最长子串
3. 无重复字符的最长子串 题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最 ...
- 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)
目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...
- 【LeetCode】Longest Substring Without Repeating Characters(无重复字符的最长子串)
这道题是LeetCode里的第3道题. 题目描述: 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: ...
- LeetCode Golang 3. 无重复字符的最长子串
3. 无重复字符的最长子串 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串 ...
随机推荐
- Linux内核调试的方式以及工具集锦
原文:https://blog.csdn.net/gatieme/article/details/68948080 CSDN GitHubLinux内核调试的方式以及工具集锦 LDD-LinuxDev ...
- 小程序支付及H5支付前端代码小结
小程序支付和H5支付前端都不需要引入其他的js , 只需要后台将相关的参数 ( timeStamp: '', nonceStr: '', package: '', signType: 'MD5', p ...
- WinDbg常用命令系列---!dlls
!dlls 简介 !dlls扩展显示所有加载模块或指定线程或进程正在使用的所有模块的表条目. 使用形式 !dlls [Options][LoaderEntryAddress] !dlls -h 参数 ...
- Linux常用命令合集
常用命令合集 命令选项和参数 Linux中的命令格式为:command [options] [arguments] //中括号表示可选的,即有些命令不需要选项也不需要参数,但有的命令在运行时需要多个 ...
- 数据分析师(Data Analyst),数据工程师(Data Engineer),数据科学家(Data Scientist)的区别
数据分析师(Data Analyst):负责从数据中提取出有用的信息,以帮助公司形成业务决策.工作内容包括:对数据进行提取,清洗,分析(用描述统计量,趋势分析,多维度分析,假设检验等统计常用方法对数据 ...
- 多项式乘法,sb题
给定一个n,输出\((a1+x)*(a2+x)*...(an+x)\)的多项式长度. 每一个字符(包括"a"."x"."(".") ...
- 群晖采用root用户登录
在控制面板中开启 ssh 登录 通过有 管理员权限的用户登录 通过输入 sudo -i 或者 sudo su - , 然后输入当前用户密码, 进入 root 输入如下命令可以修改root 用户的密码 ...
- 用jquery做一个带导航的名单列表
代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...
- element ui 怎么去修改el-date-picker的时间
<el-date-picker v-model="formSearch.timeRange" type="daterange" placeholder=& ...
- java 优秀开源项目
一.https://github.com/zhangdaiscott/jeecg-boot 简介:一款基于代码生成器的JAVA快速开发平台!全新架构前后端分离:SpringBoot 2.x,Ant D ...