Leetcode 最长不含重复字符的子字符串

在这里插入图片描述

解题思路:本题的目的是在给定的字符串中,找出一个不含相同字母的子串。因此首先想到滑动窗口,即给定一个left和一个right,维护一个不包含相同字母子串的窗口。使用一个集合set作为辅助,每次将right向右移动一次,如果right对应的字符没有出现在set中,则无需操作;反之,则清除掉set中所有元素,重新计算滑窗,并将left移动到此时right的位置。right每次向右移动,都让结果res取 max(res, right-left+1)。

AC代码:

class Solution {
    public int lengthOfLongestSubstring(String s) {
        Set<Character> set = new HashSet<>();
        int res = 0;
        for(int l=0, r=0; r<s.length(); r++)
        {
            char c = s.charAt(r);
            while(set.contains(c))
            {
                set.remove(s.charAt(l));
                l++;
            }
            set.add(c);
            res = Math.max(res, r-l+1);
        }
        return res;
    }
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值