Longest Substring Without Repeating Characters

Posted tz346125264

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Longest Substring Without Repeating Characters相关的知识,希望对你有一定的参考价值。

题意:求一个字符串的最长不含重复字符的子字符串长度;

示例:

input:pwwkw

output:2

intput:dvdf

output:3

 

分析:还是那句话,每分析一个问题的时候都要问自己,自己的大脑是如何找出正确答案的,将自己的分析转化为代码此题便解

题目要求不含重复字符,且是子字符串;

1. 以输入一为例,当数到pw时,重复字符便出现了(字符串长度为2);

2. 于是从第二个w重新计数,到wk时,重复字符再出现(字符串长度为2);

3. 如此到最后一个字符,结果便为2;

提炼出:遇到重复字符,字符长度需重新计数,最终得到这些字符长度的最大值;

如此首先我们需要判定字符是否之前出现过,其次回想一下我们是如何计数的,即当前位置-重复字符出现的那一位置+1,那么我们便需要记录字符出现的位置

那么我们便可以使用一个数组来记录字符出现的位置(数组下标为字符,值为位置index),若未出现过则值为0

如此代码如下:

public int lengthOfLongestSubstring(String s) {
        int[] site = new int[256];
        int left = 0;
        int max = 0;
        for (int i = 0; i < s.length(); i++) {
            char ch = s.charAt(i);
            if (site[ch] == 0 || site[ch] < left) {
                max = Math.max(max, i - left + 1);
            } else {
                left = site[ch];
            }
            site[ch] = i + 1;
        }
        return max;
    }

 

以上是关于Longest Substring Without Repeating Characters的主要内容,如果未能解决你的问题,请参考以下文章

3. Longest Substring Without Repeating Characters

Leetcode-Longest Substring Without Repeating Characters

[LeetCode] Longest Substring Without Repeating Characters

Longest Substring Without Repeating Characters

Leetcode 3. Longest Substring Without Repeating Characters

leetcode: Longest Substring Without Repeating Characters