无重复字符的最长子串Java版(力扣)

简介: 无重复字符的最长子串Java版(力扣)

无重复字符的最长子串


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


示例 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 由英文字母、数字、符号和空格组成


题意:找出其中不含有重复字符的 最长子串 的长度

思路:滑动窗口


正确代码:


class Solution {
    public int lengthOfLongestSubstring(String s) {
        HashMap<Character,Integer> map = new HashMap<Character, Integer>();
        int left=0;
        int max=0;
        for (int i = 0; i < s.length(); i++) {
            if(map.containsKey(s.charAt(i))){
                left=Math.max(left,map.get(s.charAt(i))+1);
            }
            map.put(s.charAt(i),i);
            max=Math.max(max,i-left+1);
        }
        return max;
    }
}

完整代码(含测试代码):


package com.Keafmd.February.day11;
import java.util.HashMap;
import java.util.Map;
/**
 * Keafmd
 *
 * @ClassName: LongestSubstringWithoutRepeatingCharacters
 * @Description: 无重复字符的最长子串 https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/
 * @author: 牛哄哄的柯南
 * @Date: 2021-03-11 8:23
 * @Blog: https://keafmd.blog.csdn.net/
 */
public class LongestSubstringWithoutRepeatingCharacters {
    public static void main(String[] args) {
        String s1= "pwwkew";
        Solution0311 solution0311 = new Solution0311();
        int result = solution0311.lengthOfLongestSubstring(s1);
        System.out.println(result);
    }
}
class Solution0311 {
    public int lengthOfLongestSubstring(String s) {
        HashMap<Character,Integer> map = new HashMap<Character, Integer>();
        int left=0;
        int max=0;
        for (int i = 0; i < s.length(); i++) {
            if(map.containsKey(s.charAt(i))){
                left=Math.max(left,map.get(s.charAt(i))+1);
            }
            map.put(s.charAt(i),i);
            max=Math.max(max,i-left+1);
        }
        return max;
    }
}

输出结果:


3
Process finished with exit code 0


相关文章
|
2月前
|
Java
Java——编码GBK的不可映射字符
Java——编码GBK的不可映射字符
34 1
|
2月前
|
存储 Java Apache
|
3月前
|
Java API 索引
Java中的字符串与字符操作详解
Java中的字符串与字符操作详解
|
3月前
|
Java API 索引
Java中的字符串与字符操作详解
Java中的字符串与字符操作详解
|
5天前
|
安全 Java 调度
Java编程时多线程操作单核服务器可以不加锁吗?
Java编程时多线程操作单核服务器可以不加锁吗?
18 2
|
9天前
|
存储 缓存 Java
java线程内存模型底层实现原理
java线程内存模型底层实现原理
java线程内存模型底层实现原理
|
13天前
|
缓存 Java 应用服务中间件
Java虚拟线程探究与性能解析
本文主要介绍了阿里云在Java-虚拟-线程任务中的新进展和技术细节。
|
11天前
|
Java 开发者
Java中的多线程基础与应用
【9月更文挑战第22天】在Java的世界中,多线程是一块基石,它支撑着现代并发编程的大厦。本文将深入浅出地介绍Java中多线程的基本概念、创建方法以及常见的应用场景,帮助读者理解并掌握这一核心技术。
|
6天前
|
Java 调度
Java-Thread多线程的使用
这篇文章介绍了Java中Thread类多线程的创建、使用、生命周期、状态以及线程同步和死锁的概念和处理方法。
Java-Thread多线程的使用
下一篇
无影云桌面