寒假打卡:2026-2-7

日常学习:算法

⽆重复字符的最⻓⼦串

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

示例 1:

复制代码
输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。注意 "bca" 和 "cab" 也是正确答案。

示例 2:

复制代码
输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

复制代码
输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

算法思想:

利用规律,使用"滑动窗口"来解决问题

(1)left=0,right=0;

(2)进窗口:让字符进入哈希表

(3)判断:窗口是否出现重复字符

-->出窗口-->从哈希表中删除字符-->更新结果

java 复制代码
class Solution
{
public int lengthOfLongestSubstring(String ss)
{
char[] s = ss.toCharArray();
int[] hash = new int[128]; // ⽤数组模拟哈希表
int left = 0, right = 0, n = ss.length();
int ret = 0;
while(right < n)
{
hash[s[right]]++; // 进⼊窗⼝
while(hash[s[right]] > 1) // 判断
hash[s[left++]]--; // 出窗⼝
ret = Math.max(ret, right - left + 1); // 更新结果
right++; // 让下⼀个字符进⼊窗⼝
}
return ret;
}
}
相关推荐
桦说编程20 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
ssshooter20 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
Live000001 天前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉1 天前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
躺平大鹅1 天前
Java面向对象入门(类与对象,新手秒懂)
java
球球pick小樱花1 天前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
喝水的长颈鹿1 天前
【大白话前端 02】网页从解析到绘制的全流程
前端·javascript
用户14536981458781 天前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
codingWhat1 天前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js