【Day34】LeetCode算法 -- 3. 无重复字符的最长子串

简介: 学习LeetCode算法 -- 3. 无重复字符的最长子串。

刷题打卡,第 34 天


题目一、3. 无重复字符的最长子串


题目一、3. 无重复字符的最长子串


原题链接:3. 无重复字符的最长子串


题目描述:


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

/

示例 1:

输入: s = “abcabcbb”

输出: 3

解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。

/

示例 2:

输入: s = “bbbbb”

输出: 1

解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。

/

示例 3:

输入: s = “pwwkew”

输出: 3

解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。

请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。

/

提示:


0 <= s.length <= 5 * 104

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

解题思路:

题目会给定一个字符串s,我们需要返回其中最长子串的长度,注意,这里返回的是最长子串长度而非最长子序列长度。例如:“abbcde”,最长子串是“bcde” ; 最长子序列是“abcde” ;


我们可以模拟出一个窗口来扫描字符串的每一个字符,窗口有左边界和右边界,我么用下标left = 0和下标right = 0来对应左右边界,在接下来的扫描中,我们会遇到两种情况:


扫描到的字符不存在于窗口中,那么我们的右边界right + 1后移,将元素包含进窗口中,记录下当前窗口的最大长度,对应着当前不重复子串的最大长度,然后继续扫描剩下的字符。

扫描到的字符在窗口中存在,那么这时候我们就需要将左边界 left + 1后移,缩短窗口,重复这样的操作直到当前扫描的元素不存在于窗口中。

循环进行上述操作,当我们窗口的有边界抵达字符串s的尾部,也就是扫描完整个字符串后,返回记录下来的当前最大子串长度即可。


为了判断扫描到的元素是否存在于窗口中,我们会使用到内容不可重复的集合Set,用Set集合充当窗口,将扫描到的字符用Set集合来保存,能成功保存就说明当前元素不存在于窗口中,不能添加就说明当前元素存在于窗口中。


提交代码:

class Solution {
    public int lengthOfLongestSubstring(String s) {
        if(s == null || s.length() == 0) return 0; //若字符串为空或长度为0,直接返回0
      Set<Character> set = new HashSet<>();      //创建不可重复的Set集合,充当扫描的窗口
        int left = 0,right = 0,max = 0;    //左边界下标left,右边界下标right,最长不重复子串长max
        int length = s.length();           //获取字符串的长度
    while(right < length){             //在字符串被扫描完之前
            char r = s.charAt(right);      //扫描right下标位置的值
            if(set.add(r)){                //如果成功加入Set集合
                max = Math.max(max,right-left+1);//记录当前最长不重复子串的长度
                ++right;                         //向后扫描
            }else{                         //如果无法加入Set集合
                char l = s.charAt(left);   
                set.remove(l);             //left下标后移,缩减窗口长度
                ++left;                    
            }
        }
        return max;  //返回记录下的窗口历史最长大小,即:最长子串的长度。
    }
}

提交结果:

微信图片_20221031171436.png

⚽求关注⚽ 作者🥇 .29. 🥇 的✔博客主页✔

⚽来刷题⚽ 记录每日LeetCode✔刷题专栏✔

您的点赞,收藏以及关注是对作者最大的鼓励喔 ~~

微信图片_20221029111446.jpg




目录
相关文章
|
11天前
|
算法 C++
【优选算法】——滑动窗口——3. 无重复字符的最长子串
【优选算法】——滑动窗口——3. 无重复字符的最长子串
|
11天前
|
算法
【优选算法】——Leetcode——LCR 179. 查找总价格为目标值的两个商品
【优选算法】——Leetcode——LCR 179. 查找总价格为目标值的两个商品
|
11天前
|
算法
【优选算法】——Leetcode——611. 有效三角形的个数
【优选算法】——Leetcode——611. 有效三角形的个数
|
11天前
|
算法 容器
【优选算法】—Leetcode—11—— 盛最多水的容器
【优选算法】—Leetcode—11—— 盛最多水的容器
|
11天前
|
算法
【优选算法】——Leetcode——202—— 快乐数
【优选算法】——Leetcode——202—— 快乐数
【优选算法】——Leetcode——202—— 快乐数
|
11天前
|
算法
[优选算法]——双指针——Leetcode——1089. 复写零
[优选算法]——双指针——Leetcode——1089. 复写零
|
19天前
|
算法 数据安全/隐私保护 计算机视觉
基于二维CS-SCHT变换和LABS方法的水印嵌入和提取算法matlab仿真
该内容包括一个算法的运行展示和详细步骤,使用了MATLAB2022a。算法涉及水印嵌入和提取,利用LAB色彩空间可能用于隐藏水印。水印通过二维CS-SCHT变换、低频系数处理和特定解码策略来提取。代码段展示了水印置乱、图像处理(如噪声、旋转、剪切等攻击)以及水印的逆置乱和提取过程。最后,计算并保存了比特率,用于评估水印的稳健性。
|
3天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于DCT变换和位平面分解的数字水印嵌入提取算法matlab仿真
这是一个关于数字水印算法的摘要:使用MATLAB2022a实现,结合DCT和位平面分解技术。算法先通过DCT变换将图像转至频域,随后利用位平面分解嵌入水印,确保在图像处理后仍能提取。核心程序包括水印嵌入和提取,以及性能分析部分,通过PSNR和NC指标评估水印在不同噪声条件下的鲁棒性。
|
4天前
|
算法 数据安全/隐私保护 C++
基于二维CS-SCHT变换和扩频方法的彩色图像水印嵌入和提取算法matlab仿真
该内容是关于一个图像水印算法的描述。在MATLAB2022a中运行,算法包括水印的嵌入和提取。首先,RGB图像转换为YUV格式,然后水印通过特定规则嵌入到Y分量中,并经过Arnold置乱增强安全性。水印提取时,经过逆过程恢复,使用了二维CS-SCHT变换和噪声对比度(NC)计算来评估水印的鲁棒性。代码中展示了从RGB到YUV的转换、水印嵌入、JPEG压缩攻击模拟以及水印提取的步骤。
|
5天前
|
机器学习/深度学习 算法 数据可视化
基于BP神经网络的32QAM解调算法matlab性能仿真
```markdown - 32QAM解调算法运用BP神经网络在matlab2022a中实现,适应复杂通信环境。 - 网络结构含输入、隐藏和输出层,利用梯度下降法优化,以交叉熵损失最小化为目标训练。 - 训练后,解调通过前向传播完成,提高在噪声和干扰中的数据恢复能力。 ``` 请注意,由于字符限制,部分详细信息(如具体图示和详细步骤)未能在摘要中包含。