Lc3-无重复字符的最长子串
import java.util.HashMap; import java.util.Map; /* * Given a string, find the length of the longest substring without repeating characters. Example 1: Input: "abcabcbb" Output: 3 Explanation: The answer is "abc", with the length of 3. Example 2: Input: "bbbbb" Output: 1 Explanation: The answer is "b", with the length of 1. Example 3: Input: "pwwkew" Output: 3 Explanation: The answer is "wke", with the length of 3. Note that the answer must be a substring, "pwke" is a subsequence and not a substring. */ public class Lc3 { // ·滑动窗口 public static int lengthOfLongestSubstring(String s) { // key 值 - 当前值,value 值-当前的位置 Map<Character, Integer> map = new HashMap<Character, Integer>(); int ans = 0; char[] ch = s.toCharArray(); for (int end = 0, start = 0; end < ch.length; end++) { // ·如果map包含当前值,更新其位置 if (map.containsKey(ch[end])) { start = Math.max(map.get(ch[end]), start); } // ·每次更新最大距离,当前位置减去上一次重复的位置,再往后加一位即是本次的最大距离 ans = Math.max(ans, end - start + 1); map.put(ch[end], end + 1); } return ans; } public static void main(String[] args) { String s = "dvdf"; System.out.println(lengthOfLongestSubstring(s)); } }
不恋尘世浮华,不写红尘纷扰
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理