時念
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
    • JavaScript 基础
  • 后端笔记

    • Java
    • Spring
    • 算法
    • 高可用
    • 高并发
  • 工作问题

    • 问题记录
  • 各类工具使用
  • GitHub技巧
  • 博客搭建
  • 面试题库

    • 零碎
    • 面试常见题目汇总
  • 面试心得

    • 面试集锦
    • 杂言碎语
  • 摘抄收录

    • ☆ 励志鸡汤
    • ❀ 人间烟火
    • ☣ 万物沦丧
    • ✌ 关掉烦恼
    • ✲ 小酒馆
  • 读书笔记

    • 《小狗钱钱》
    • 《穷爸爸富爸爸》
    • 《聪明人使用方格笔记本》
  • 学习
  • 心情杂货
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub

時念

一个有梦想的后端小菜鸡(✪ω✪)
首页
  • 前端文章

    • JavaScript
    • Vue
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《ES6 教程》笔记
    • 《Vue》笔记
    • 《TypeScript 从零实现 axios》
    • 小程序笔记
    • JavaScript 基础
  • 后端笔记

    • Java
    • Spring
    • 算法
    • 高可用
    • 高并发
  • 工作问题

    • 问题记录
  • 各类工具使用
  • GitHub技巧
  • 博客搭建
  • 面试题库

    • 零碎
    • 面试常见题目汇总
  • 面试心得

    • 面试集锦
    • 杂言碎语
  • 摘抄收录

    • ☆ 励志鸡汤
    • ❀ 人间烟火
    • ☣ 万物沦丧
    • ✌ 关掉烦恼
    • ✲ 小酒馆
  • 读书笔记

    • 《小狗钱钱》
    • 《穷爸爸富爸爸》
    • 《聪明人使用方格笔记本》
  • 学习
  • 心情杂货
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub
  • java

  • spring

  • 问题记录

  • 算法

    • 链表
    • 双指针
    • 二叉树
    • 回溯
    • (伪)二分
    • 堆
    • 贪心
    • 动态规划
    • 多维动态规划
    • 技巧
    • 数组
    • 子串
    • 滑动窗口
      • 无重复最长子串
      • 字符串的所以字母异位词
    • 哈希
    • (伪)栈
    • 数组混淆点整理
  • 高可用

  • 后端
  • 算法
時念
2023-12-20

滑动窗口

# 无重复最长子串

class Solution {
    public int lengthOfLongestSubstring(String s) {
        if(s == null){
            return 0;
        }
        int l = 0;
        int r = 0;
        int res = 0;
        Set<Character> set = new HashSet<>();
        while(r< s.length()){
            char c = s.charAt(r);
            while(set.contains(c)){
                char d = s.charAt(l);
                set.remove(d); 
                l++;
            }
            set.add(c);
            res = Math.max(res, set.size());
            r++;
        }
        return res;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

# 字符串的所以字母异位词

class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        Map<Character, Integer> windows = new HashMap<>();
         Map<Character, Integer> need = new HashMap<>();
         for(int i = 0; i < p.length(); i++){
             need.put(p.charAt(i), need.getOrDefault(p.charAt(i), 0)+1);
         }
         int left = 0;
         int right = 0;
         int vaildate = 0;
         List<Integer>  res = new ArrayList<>();
         while(right < s.length()){
             char c = s.charAt(right);
             right++;
             if(need.containsKey(c)){
                windows.put(c, windows.getOrDefault(c,0)+1);
                if(windows.get(c).equals(need.get(c))){
                    vaildate++;
                }
             }
             while(right -left >=  p.length()){
                 if(vaildate == need.size()){
                     res.add(left);
                 }
                 char d = s.charAt(left);
                 left++;
                 if(need.containsKey(d)){
                    if(windows.get(d).equals(need.get(d))){
                        vaildate--;
                    }
                    windows.put(d, windows.getOrDefault(d,0)-1);
             }
             }
         }
         return res;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
编辑
上次更新: 2024/03/26, 9:03:00
子串
哈希

← 子串 哈希 →

最近更新
01
database-shard-dynamic-expand
03-26
02
README
03-26
03
database-shard-global-id-generate
03-26
更多文章>
Theme by Vdoing | Copyright © 2019-2024 時念 | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式