滑动窗口 | Java | (hot100) 力扣 3

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

暴力法:双层for循环,i-j的字符查重

滑动窗口:因为这题被分在这个类别里,那么已知要用滑动窗口,思路应该是什么。

反正我想不出来......

  • 看了别人的题解写出来的
  • 出错点:特别容易下标和元素弄混
java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        Set<Character>set = new HashSet<Character>();
        char ch;
        int res=0;
        for(int left=0,right=0; right<s.length(); right++) {
            ch = s.charAt(right);
            while(set.contains(ch)) {
                set.remove(s.charAt(left)); //注意这里是用left
                left++;
            }
            set.add(ch);
            res = Math.max(res, right-left+1);
        }
        return res;
    }
}

ACM模式练习 https://www.acwing.com/problem/content/57/

滑动窗口模板

java 复制代码
//外层循环扩展右边界,内层循环扩展左边界
for (int l = 0, r = 0 ; r < n ; r++) {
	//当前考虑的元素
	while (l <= r && check()) {//区间[left,right]不符合题意
        //扩展左边界
    }
    //区间[left,right]符合题意,统计相关信息
}

本题变形

腾讯面试题,需要返回的是子串(来自力扣评论)

我的思路:在这一句下功夫:res = Math.max(res, right-left+1);

多设置一个变量 strLeft,当更新res的时候,strLeft = left。当for循环结束,知道子串长度res和字串起始值strLeft就可以返回字串了

java 复制代码
public class Collection01 {
    public static void main(String[] args) {
        lengthOfLongestSubstring("pwwkew");
    }


    public static int lengthOfLongestSubstring(String s) {
        Set<Character>set = new HashSet<Character>();
        char ch;
        int res=0;
        int strleft=0;
        for(int left=0,right=0; right<s.length(); right++) {
            ch = s.charAt(right);
            while(set.contains(ch)) {
                set.remove(s.charAt(left)); //注意这里是用left
                left++;
            }
            set.add(ch);
            if((right-left+1)>res) {
                res = right-left+1;
                strleft = left;
            }
        }
        System.out.println(res);
        System.out.println(strleft);
        System.out.println(s.substring(strleft,strleft+res));
        return res;
    }

}
相关推荐
好学且牛逼的马5 分钟前
【Hot100|21-LeetCode 160. 相交链表】
算法·leetcode
nbsaas-boot5 分钟前
如何进行 Vibe Coding:从“灵感驱动”到“可交付工程”的方法论
java·ai编程
Remember_9939 分钟前
Spring 事务深度解析:实现方式、隔离级别与传播机制全攻略
java·开发语言·数据库·后端·spring·leetcode·oracle
roman_日积跬步-终至千里13 分钟前
【Java并发】用 JMM 与 Happens-Before 解决多线程可见性与有序性问题
java·开发语言·spring
空空kkk14 分钟前
SSM项目练习——hami音乐(三)
java·数据库
爬山算法22 分钟前
Hibernate(78)如何在GraphQL服务中使用Hibernate?
java·hibernate·graphql
独断万古他化27 分钟前
【Spring 核心:AOP】基础到深入:思想、实现方式、切点表达式与自定义注解全梳理
java·spring·spring aop·aop·切面编程
编程彩机39 分钟前
互联网大厂Java面试:从分布式事务到微服务优化的技术场景解读
java·spring boot·redis·微服务·面试·kafka·分布式事务
bbq粉刷匠40 分钟前
Java-排序2
java·数据结构·排序算法
编程彩机42 分钟前
互联网大厂Java面试:从Spring WebFlux到分布式事务的技术场景解析
java·微服务·面试·分布式事务·spring webflux