day14(11.14)——leetcode面试经典150

3. 无重复字符的最长子串

今天的题顺利写出来了!!!

3. 无重复字符的最长子串

题目:

题解:

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        // 左边界
        int l=0;
        // 不断找最长字符串
        StringBuilder str=new StringBuilder();
        // 最长不重复的长度
        int maxx = 0;
        int index = -1;
        for(int i=0;i<s.length();i++) {
            // StringBuilder 的 indexOf 方法 **只接受 String 参数!
            index = str.indexOf(String.valueOf(s.charAt(i)));
            // 说明在字符串中找到了当前的i
            if(index!=-1) {
                l=index+1;
                str.delete(0,l);
            }
            //这里不能用else,因为如果有重复元素,
            //我们需要把在str中的0-重复元素之间全部删掉,
            //再把当前的i加入,如果没有重复元素,也应该把当前的i加入,
            //这样更新最长长度
            
            // 将当前字符加入str中
            str.append(s.charAt(i));
            // 更新最长
            maxx=Math.max(maxx,str.length());
        }
        return maxx;
    }
}
相关推荐
HXhlx3 小时前
CART决策树基本原理
算法·机器学习
Wect3 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱4 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway10 小时前
解析残差网络 (ResNet)
算法
拖拉斯旋风11 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect11 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript
灵感__idea1 天前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect1 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP2 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱2 天前
单调栈:从模板到实战
javascript·后端·算法