leetCode算法题之无重复字符的最长子串

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


示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:

输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
示例 4:

输入: s = ""
输出: 0
 

提示:

0 <= s.length <= 5 * 104
s 由英文字母、数字、符号和空格组成

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解法思路:

	利用滑动窗口思想,从头开始遍历字符串,遍历所有无重复子串,然后得到最大的长度。
	时间复杂度:O(n);
	空间复杂度:O(m);

举例:

输入: s = "pwwkew"
对字符串遍历,从下标k=0开始,当k为2的时候则出现重复字符,此时下标k移动到2,最大不重复长度为2。然后k继续向后移动,当k为5的时候出现重复字符,此时最大不重复长度为5-2

具体代码如下:

public static int lengthOfLongestSubstring(String s) {
        List<Character> occ = new ArrayList<>();
        int n = s.length();
        int rk = -1;
        int ans = 0;
        for (int i = 0; i < n+1; i++) {
            if (i != 0) {
                occ.remove(Character.valueOf(s.charAt(i-1)));
            }
            while (rk + 1 < n && !occ.contains(s.charAt(rk + 1))) {
                occ.add(s.charAt(rk+1));
                rk = rk + 1;
            }
            ans = Math.max(ans, rk-i+1);
        }
        return ans;
    }
posted @ 2021-12-19 20:30  昨夜风雨声  阅读(8)  评论(0编辑  收藏  举报  来源