【LeetCode】第8天 - 3. 无重复字符的最长子串 | 567 字符串的排列

简介: 【LeetCode】第8天 - 3. 无重复字符的最长子串 | 567 字符串的排列

题目描述

题目1(3. 无重复字符的最长子串)

在这里插入图片描述

题目2(567 字符串的排列)

在这里插入图片描述

解题思路

题目1(3. 无重复字符的最长子串)

  • 使用一个哈希表map存储无重复字符的字串(key),以及在字符串中的位置(value)
  • 使用两个指针(start,end)分别指向无重复字符字串的首尾
  • 遍历字符串的每个字符,如果map中不存在该字符,将其加入map,并更新当前最大无重复字串长度;若存在,更新start位置。

题目2(567 字符串的排列)

遍历 s2 中的每个长度为 s1.length() 的子串,判断子串和 s1​ 中每个字符的出现次数是否相等,若相等,返回true。

代码实现

题目1(3. 无重复字符的最长子串)

class Solution {
    public int lengthOfLongestSubstring(String s) {
        int n = s.length();
        Map<Character, Integer> map = new HashMap<>();
        int maxLength = 0, start = 0;
        for(int end=0;end<n;end++){
            char temp = s.charAt(end);    //当前字符
            if(map.containsKey(temp)){
                start = Math.max(map.get(temp)+1, start);
            }
            maxLength = Math.max(maxLength, end - start + 1);
            map.put(temp, end);
        }
        return maxLength;
    }
}

题目2(567 字符串的排列)

class Solution {
    public boolean checkInclusion(String s1, String s2) {
        if(s1.length() > s2.length()) return false;    //s1长度必定不大于s2
        int[] count1 = new int[26];
        int[] count2 = new int[26];

        for(int i=0;i<s1.length();i++){
            ++count1[s1.charAt(i) - 'a'];
            ++count2[s2.charAt(i) - 'a'];
        }
        if(Arrays.equals(count1, count2)) return true;

        for(int i=s1.length();i<s2.length();i++){
            ++count2[s2.charAt(i) - 'a'];
            --count2[s2.charAt(i-s1.length()) - 'a'];
            if(Arrays.equals(count1, count2)) return true;
        }
        return false;
    }
}
目录
相关文章
|
3月前
|
算法 C++ 容器
Leetcode第三十一题(下一个排列)
这篇文章介绍了LeetCode第31题“下一个排列”的C++解决方案,该算法通过原地修改数组来找到下一个字典序更大的排列,如果不存在则重排为字典序最小的排列。
43 0
Leetcode第三十一题(下一个排列)
|
3月前
|
存储 算法
Leetcode第三题(无重复字符的最长子串)
这篇文章介绍了解决LeetCode第三题“无重复字符的最长子串”的算法,使用滑动窗口技术来找出给定字符串中最长的不含重复字符的子串,并提供了详细的代码实现和解释。
126 0
Leetcode第三题(无重复字符的最长子串)
|
3月前
|
JavaScript
力扣3333.找到初始输入字符串Ⅱ
【10月更文挑战第9天】力扣3333.找到初始输入字符串Ⅱ
45 1
|
3月前
|
C++
Leetcode第43题(字符串相乘)
本篇介绍了一种用C++实现的字符串表示的非负整数相乘的方法,通过逆向编号字符串,将乘法运算转化为二维数组的累加过程,最后处理进位并转换为字符串结果,解决了两个大数相乘的问题。
33 9
|
3月前
|
算法 C++
Leetcode第八题(字符串转换整数(atoi))
这篇文章介绍了LeetCode上第8题“字符串转换整数(atoi)”的解题思路和C++的实现方法,包括处理前导空格、正负号、连续数字字符以及整数溢出的情况。
27 0
|
3月前
【LeetCode 22】459.重复的子字符串
【LeetCode 22】459.重复的子字符串
36 0
|
3月前
【LeetCode 20】151.反转字符串里的单词
【LeetCode 20】151.反转字符串里的单词
30 0
|
3月前
【LeetCode 19】541.反转字符串II
【LeetCode 19】541.反转字符串II
28 0
|
3月前
【LeetCode 18】6.2.反转字符串
【LeetCode 18】6.2.反转字符串
26 0
|
5月前
|
存储 算法
LeetCode第43题字符串相乘
LeetCode第43题"字符串相乘"的解题方法,通过使用数组存储乘积并处理进位,避免了字符串转换数字的复杂性,提高了算法效率。
LeetCode第43题字符串相乘