【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;
    }
}
目录
相关文章
|
算法 C++ 容器
Leetcode第三十一题(下一个排列)
这篇文章介绍了LeetCode第31题“下一个排列”的C++解决方案,该算法通过原地修改数组来找到下一个字典序更大的排列,如果不存在则重排为字典序最小的排列。
120 0
Leetcode第三十一题(下一个排列)
|
存储 算法
Leetcode第三题(无重复字符的最长子串)
这篇文章介绍了解决LeetCode第三题“无重复字符的最长子串”的算法,使用滑动窗口技术来找出给定字符串中最长的不含重复字符的子串,并提供了详细的代码实现和解释。
600 0
Leetcode第三题(无重复字符的最长子串)
|
7月前
|
Go 索引
【LeetCode 热题100】394:字符串解码(详细解析)(Go语言版)
本文详细解析了 LeetCode 热题 394:字符串解码。题目要求对编码字符串如 `k[encoded_string]` 进行解码,其中 `encoded_string` 需重复 `k` 次。文章提供了两种解法:使用栈模拟和递归 DFS,并附有 Go 语言实现代码。栈解法通过数字栈与字符串栈记录状态,适合迭代;递归解法则利用函数调用处理嵌套结构,代码更简洁。两者时间复杂度均为 O(n),但递归需注意栈深度问题。文章还总结了解题注意事项及适用场景,帮助读者更好地掌握字符串嵌套解析技巧。
193 6
|
8月前
|
存储 机器学习/深度学习 缓存
🚀 力扣热题 394:字符串解码(详细解析)(Go语言版)
文章提供了两种解法:栈结构和递归解法。栈解法通过维护数字栈与字符串栈,依次处理 `[` 和 `]`,构造解码结果;递归解法则利用函数调用逐层解析嵌套结构。两者时间复杂度均为 $O(n)$,空间复杂度也为 $O(n)$。栈解法直观易懂,适合初学者;递归解法优雅简洁,适合处理深度嵌套规则。掌握这两种方法,可灵活应对类似问题,提升解题能力。
278 11
|
C++
Leetcode第43题(字符串相乘)
本篇介绍了一种用C++实现的字符串表示的非负整数相乘的方法,通过逆向编号字符串,将乘法运算转化为二维数组的累加过程,最后处理进位并转换为字符串结果,解决了两个大数相乘的问题。
117 9
|
JavaScript
力扣3333.找到初始输入字符串Ⅱ
【10月更文挑战第9天】力扣3333.找到初始输入字符串Ⅱ
157 1
|
算法 C++
Leetcode第八题(字符串转换整数(atoi))
这篇文章介绍了LeetCode上第8题“字符串转换整数(atoi)”的解题思路和C++的实现方法,包括处理前导空格、正负号、连续数字字符以及整数溢出的情况。
172 0
【LeetCode 22】459.重复的子字符串
【LeetCode 22】459.重复的子字符串
131 0
【LeetCode 20】151.反转字符串里的单词
【LeetCode 20】151.反转字符串里的单词
117 0
【LeetCode 19】541.反转字符串II
【LeetCode 19】541.反转字符串II
100 0