3、无重复字符的最长子串(C#)

        我们趁热打铁,再来看看第三题,第三题题目边长了,名字一寸长一寸强,让我们来一起看看这一题是真难,还是纸老虎呢?

关卡三:无重复字符的最长子串

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

我的分析 

        名字长,题目短,典型有难度题的象征。首先大家不要被想复杂了,题目明确说明了,是让你求子串长度,不是让你求子串,这里最开始我也看错了,所以走了些弯路。看到这种去重的题,首先在我们平常使用最多的去重方法是什么?没错,就是使用HashSet,HashSet 基于 HashMap 来实现的,是一个不允许有重复元素的集合。首先我们可以设置两个索引,然后第一个索引往前找,将找到的元素添加到HashSet中并计数。如果发现重复就删除前面的元素,减去相应的计数,最后取这个计数作为最大值即可,即长度。

public class Solution {
    public int LengthOfLongestSubstring(string s) {
        HashSet<char> hset = new HashSet<char>();
        int l = 0,r = 0;   //表示前后索引
        int max = 0,count = 0;
        while(r<s.Length)
        {
            if(!hset.Contains(s[r])){
                hset.Add(s[r]);
                r++;
                count++;
            }
            else
            {
                hset.Remove(s[l]);
                l++;
                count--;
            }
            max = Math.Max(max,count);
        }
        return max;
    }
}

  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想摘月亮送给你

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值