最长不含重复字符的字符号串


class Solution {
    public int lengthOfLongestSubstring(String s) {
     if(s.length()==0) return 0;   
//双指针(r指针最先向右移动,遇到重复的l指针向右移动直到越过重复的r指针继续向右移动)
    int l=0,r=0,res=0;
    Map<Character,Integer> map = new HashMap<>();
    while(l<=r){
        char ch_r = s.charAt(r);
        map.put(ch_r,map.getOrDefault(ch_r,0)+1);
        while(map.get(ch_r)>1){
            char ch_l = s.charAt(l);
            map.put(ch_l,map.getOrDefault(ch_l,0)-1);
            l++;
        }
        res = res > r-l+1? res:r-l+1;
        r++;
        if(r==s.length()) break;

    }
    return res;
    }
}

posted @   浅滩浅  阅读(274)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
阅读排行:
· 从零开始开发一个 MCP Server!
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
· Browser-use 详细介绍&使用文档
历史上的今天:
2019-07-18 华为2019秋招笔试真题
点击右上角即可分享
微信分享提示