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

题目链接:3. 无重复字符的最长子串 - 力扣(LeetCode)

1.常规解法

遍历这个字符串,用一个字符数组存储遍历中每一个字符出现的次数,若次数为0,则添加到字符数组中,并将该字符对应的值加1,若该字符次数为1,则说明子串中已经有了这个字符,若添加就会出现重复字符,退出循环,记录子串的长度,继续下一轮循环,代码如下:

java 复制代码
    public int lengthOfLongestSubstring(String s) {
        int len = 0;
        int sLen = s.length();
        for (int i = 0; i < sLen; i++) {
            int[] arr = new int[128];
            int j = i;
            for (; j < sLen; j++) {
                char ch = s.charAt(j);
                if (arr[ch] == 0) {
                    arr[ch]++;
                } else {
                    break;
                }
            }
            len = Math.max(len, j - i);
        }
        return len;
    }

2.滑动窗口

在常规解法中可以看到,第一次的子串为abc,第二次的子串为bca,而两个子串有重复的部分,即为bc,那么在第一次判断完成之后,由于下一次进来的a与子串中的a重复,于是就可以将1串中的字符逐个去除直到子串中没有a,在这种条件下,就可以使用滑动窗口来解题。

先定义两个指针left和right,两指针均指向第一个字符,再定义一个用来计数的字符数组,范围为0-127;

每次将right指向的字符在计数数组中加1,再将right向右移动一位,当right指向的字符在字符数组中已经存在时,就需要将计数数组中多余的该字符去除,即让left向右移动直到该字符只出现一次为止,记录下此时子串的长度,当right超出字符串时结束循环,流程图与代码如下:

java 复制代码
    public int lengthOfLongestSubstring(String s) {
        int sLen = s.length();
        int len = 0;
        int[] arr = new int[128];//记录字符出现的次数
        int left = 0;
        int right = 0;
        while (right < sLen) {
            char in = s.charAt(right++);
            arr[in]++;
            while (arr[in] > 1) {
                char out = s.charAt(left++);
                arr[out]--;
            }
            len = Math.max(len, right - left);
        }
        return len;
    }

希望读者能够提出建议!

相关推荐
莹莹学编程—成长记25 分钟前
string的模拟实现
服务器·c++·算法
lybugproducer27 分钟前
创建型设计模式之:简单工厂模式、工厂方法模式、抽象工厂模式、建造者模式和原型模式
java·设计模式·建造者模式·简单工厂模式·工厂方法模式·抽象工厂模式·面向对象
南客先生31 分钟前
马架构的Netty、MQTT、CoAP面试之旅
java·mqtt·面试·netty·coap
Minyy1134 分钟前
SpringBoot程序的创建以及特点,配置文件,LogBack记录日志,配置过滤器、拦截器、全局异常
xml·java·spring boot·后端·spring·mybatis·logback
百锦再34 分钟前
Java与Kotlin在Android开发中的全面对比分析
android·java·google·kotlin·app·效率·趋势
武昌库里写JAVA2 小时前
39.剖析无处不在的数据结构
java·vue.js·spring boot·课程设计·宠物管理
Nelson_hehe4 小时前
Java基础第四章、面向对象
java·语法基础·面向对象程序设计
Thomas_YXQ4 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
ShiinaMashirol5 小时前
代码随想录打卡|Day27(合并区间、单调递增的数字、监控二叉树)
java·算法
东阳马生架构7 小时前
Nacos简介—3.Nacos的配置简介
java