力扣--LCR 167.招式拆解I

题目

某套连招动作记作序列 arr,其中 arr[i] 为第 i 个招式的名字。请返回 arr 中最多可以出连续不重复的多少个招式。

示例 1:

输入:arr = "dbascDdad"

输出:6

解释:因为连续且最长的招式序列是 "dbascD" 或 "bascDd",所以其长度为 6。

示例 2:

输入:arr = "KKK"

输出:1

解释:因为无重复字符的最长子串是 "K",所以其长度为 1。

示例 3:

输入:arr = "pwwkew"

输出:3

解释:因为连续且最长的招式序列是 "wke",所以其长度为 3。

请注意区分 子串 与 子序列 的概念:你的答案必须是 连续招式 的长度,也就是 子串。而 "pwke" 是一个非连续的 子序列,不是 子串。

提示:

复制代码
0 <= arr.length <= 40000
arr 由英文字母、数字、符号和空格组成。

代码

class Solution {

// public int lengthOfLongestSubstring(String s) {

// if(s == null || s.length() <= 0){

// return 0;

// }

// // 优化 => 单个变量

// Map<Character,Integer> map = new HashMap<>();

// int[] dp = new int[s.length()];

// dp[0] = 1;

// map.put(s.charAt(0), 0);

// int res = 1;

// for(int i = 1; i < s.length(); i++){

// if(!map.containsKey(s.charAt(i))){

// dp[i] = dp[i-1] + 1;

// }else{

// int k = map.get(s.charAt(i));

// dp[i] = i - k <= dp[i-1] ? i - k : dp[i-1] + 1;

// }

// res = Math.max(res, dp[i]);

// map.put(s.charAt(i), i);

// }

复制代码
//     return res;
// }

// 优化版本
public int lengthOfLongestSubstring(String s) {
    if(s == null || s.length() <= 0){
        return 0;
    }
    // 优化 => 单个变量
    Map<Character,Integer> map = new HashMap<>();
    //int[] dp = new int[s.length()];
    int a = 1;
    map.put(s.charAt(0), 0);
    int res = 1;
    for(int i = 1; i < s.length(); i++){
        if(!map.containsKey(s.charAt(i))){
            a = a + 1;// 就是没有刷新 a 之前,a表示dp[i-1]
        }else{
            int k = map.get(s.charAt(i));
            a = i - k <= a ? i - k : a + 1;
        }
        res = Math.max(res, a);
        map.put(s.charAt(i), i);
    }

    return res;
    // 时间On,空间On
}

}

相关推荐
stolentime14 小时前
通信题:洛谷P15942 [JOI Final 2026] 赌场 / Casino题解
c++·算法·洛谷·joi·通信题
初生牛犊不怕苦14 小时前
与AI一起学习《C专家编程》:数组与指针
c语言·学习·算法
Kk.080215 小时前
数据结构|排序算法(二) 冒泡排序
数据结构·算法·排序算法
沛沛rh4515 小时前
深入并发编程:从 C++ 到 Rust 的学习笔记
c++·笔记·学习·算法·rust
Kk.080215 小时前
数据结构|排序算法(二) 希尔排序
数据结构·算法·排序算法
AI医影跨模态组学15 小时前
NPJ Precis Oncol(IF=8)复旦大学肿瘤医院等团队:基于生境CT放射组学解析可切除非小细胞肺癌时空异质性预测新辅助化疗免疫治疗病理反应
大数据·人工智能·算法·医学·医学影像
Book思议-16 小时前
二叉树的递归遍历详解:前序、中序与后序
数据结构·算法·二叉树的递归遍历-前中后序
Demon--hx16 小时前
[LeetCode]100 链表-专题
算法·leetcode·链表
Omics Pro16 小时前
首款多模态生物推理大语言模型
人工智能·算法·语言模型·自然语言处理·数据挖掘·数据分析·aigc