【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;
    }
}
目录
相关文章
|
1月前
|
存储 算法
LeetCode第43题字符串相乘
LeetCode第43题"字符串相乘"的解题方法,通过使用数组存储乘积并处理进位,避免了字符串转换数字的复杂性,提高了算法效率。
LeetCode第43题字符串相乘
|
1月前
|
算法 Java
LeetCode第28题找出字符串中第一个匹配项的下标
这篇文章介绍了LeetCode第28题"找出字符串中第一个匹配项的下标"的两种解法:暴力解法和KMP算法,并解释了KMP算法通过构建前缀表来提高字符串搜索的效率。
LeetCode第28题找出字符串中第一个匹配项的下标
|
1月前
|
算法
LeetCode第8题字符串转换整数 (atoi)
该文章介绍了 LeetCode 第 8 题字符串转换整数 (atoi)的解法,需要对字符串进行格式解析与校验,去除前导空格和处理正负号,通过从高位到低位的计算方式将字符串转换为整数,并处理越界情况。同时总结了这几道题都需要对数字的表示有理解。
LeetCode第8题字符串转换整数 (atoi)
|
1月前
|
算法
LeetCode第3题无重复字符的最长子串
该文章介绍了 LeetCode 第 3 题无重复字符的最长子串的解法,通过使用 HashSet 记录不重复的子元素,以每个字符开头遍历字符串,遇到重复字符则重新计算,最终找到最长子串,同时提到可以考虑使用 HashMap 降低复杂度。
LeetCode第3题无重复字符的最长子串
|
1月前
|
算法 Java
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
43 0
|
3月前
|
算法
力扣每日一题 6/23 字符串/模拟
力扣每日一题 6/23 字符串/模拟
27 1
|
2月前
|
索引
821.字符的最短距离-力扣(LeetCode)
821.字符的最短距离-力扣(LeetCode)
20 0
|
3月前
|
索引
力扣每日一题 6/27 字符串 贪心
力扣每日一题 6/27 字符串 贪心
24 0
|
3月前
|
Python
力扣随机一题 模拟+字符串
力扣随机一题 模拟+字符串
22 0
|
3月前
力扣每日一题 6/22 字符串/贪心
力扣每日一题 6/22 字符串/贪心
22 0