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

虽然是一道中等题,但我5分钟就写完了,而且是看完题就知道怎么写,这一看就知道双指针,一个左一个右,右指针往后移如果没有重复的长度+1;如果有重复的,左指针往右移,那如何判断重复呢,这多简单,Hashset的congtains方法啊,所以一下子就写出来了,但是效率确实不高,只击败了百分之九,以下是我的代码:

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
         int ans =0;
         int n = s.length();
         for(int i = 0;i<n;i++){
             HashSet<Character> set = new HashSet<>();
             set.add(s.charAt(i));
             int count = 1;
             for(int j = i+1;j<n;j++){
                 if(!set.contains(s.charAt(j))){
                     set.add(s.charAt(j));
                     count++;
                 }else{
                     break;
                 }
             }
             ans = Math.max(ans, count);
         }
         return ans;
    }
}

看了一下题解,题解就更优了一点,他的右指针只需要往右移动一遍即可。

字符串abcabcbb为例,找出从每一个字符开始的,不包含重复字符的最长子串,那么其中最长的那个字符串即为答案。

可以发现最长字串起始位置递增的时候,结束位置也在递增,这是因为:假如我们选第k个字符为起始位置,第r个字符是它的结束位置,那么下次选择第k+1个字符为起始位置的时候,第k+1到r一定是不重复的,而且由于少了第k个字符,那么结束位置一定大于等于r,所以右指针不需要回去,

但是题解和左右指针又不完全一样,它用的是滑动窗口,就是用一个Hashset作为一个滑动窗口,里面装了左右指针之间的这一段字符,如果左指针右移,那么hashset就要删掉左指针之前指的那个字符;如果右指针右移,那么hashset就要加入右指针新指的字符了,子串的长度就是右指针-左指针+1,以下是题解代码:

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
         int ans =0;
         int n = s.length();
         for(int i = 0;i<n;i++){
             HashSet<Character> set = new HashSet<>();
             set.add(s.charAt(i));
             int count = 1;
             for(int j = i+1;j<n;j++){
                 if(!set.contains(s.charAt(j))){
                     set.add(s.charAt(j));
                     count++;
                 }else{
                     break;
                 }
             }
             ans = Math.max(ans, count);
         }
         return ans;
    }
}
相关推荐
HaiLang_IT6 分钟前
【目标检测】基于卷积神经网络的轨道部件(扣件、轨枕、钢轨)缺陷检测算法研究
算法·目标检测·cnn
草莓熊Lotso6 分钟前
《算法闯关指南:优选算法--前缀和》--31.连续数组,32.矩阵区域和
c++·线性代数·算法·矩阵
csuzhucong8 分钟前
斜转魔方、斜转扭曲魔方
前端·c++·算法
老华带你飞11 分钟前
房屋租赁管理|基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·毕设
凛_Lin~~33 分钟前
安卓 Java线程八股文 (线程、多线程、线程池、线程安全)
android·java·开发语言
C语言不精37 分钟前
c语言-优雅的多级菜单设计与实现
c语言·开发语言·算法
哈哈哈笑什么38 分钟前
企业级CompletableFuture并行化完整方案,接口从10s到100ms
java·后端·spring cloud
AI科技星44 分钟前
张祥前统一场论:引力场与磁矢势的关联,反引力场生成及拉格朗日点解析(网友问题解答)
开发语言·数据结构·经验分享·线性代数·算法
C雨后彩虹1 小时前
最少交换次数
java·数据结构·算法·华为·面试
i***11861 小时前
【MyBatisPlus】MyBatisPlus介绍与使用
java