Rust 力扣 - 3090. 每个字符最多出现两次的最长子字符串

文章目录

题目描述

题解思路

本题使用滑动窗口进行求解,使用左指针和右指针分别表示窗口的左边界和窗口的右边界,使用哈希表记录窗口内的字符及其对应数量

我们首先向右移动右指针,将字符加入到哈希表中进行计数,如果当前加入的字符在窗口中超过3个,则右移左指针从窗口中移除元素,直到左指针把当前字符从窗口中移除一个

在移动过程中记录窗口长度的最大值,窗口长度的最大值即为本题结果

题解代码

rust 复制代码
use std::collections::HashMap;

impl Solution {
    pub fn maximum_length_substring(s: String) -> i32 {
        let s = s.as_bytes();

        let mut map = HashMap::new();

        let mut ans = 0;

        let mut left  = 0;

        for i in 0..s.len() {
            if let Some(j) = map.get(&(s[i])) {
                if *j == 2 {
                    while s[left] != s[i] {
                        if let Some(k) = map.get_mut(&s[left]) {
                            *k -= 1;
                        }

                        left += 1;
                    }
                    left += 1;

                    continue;
                } else {
                    map.insert(s[i], j + 1);
                }
            } else {
                map.insert(s[i], 1);
            }

            ans = ans.max(i - left + 1);
        }

        ans as i32
    }
}

题目链接

https://leetcode.cn/problems/maximum-length-substring-with-two-occurrences/

相关推荐
Wenhao.2 分钟前
LeetCode Hot100 腐烂的橘子
算法·leetcode·职场和发展
行走的bug...2 分钟前
支持向量机
算法·机器学习·支持向量机
苏三的开发日记3 分钟前
minio服务集群搭建
后端
开心猴爷4 分钟前
苹果iOS应用上架App Store必看指南与规则
后端
花阴偷移9 分钟前
kotlin语法(上)
android·java·开发语言·kotlin
哈哈哈笑什么10 分钟前
解决微服务系统中跨服务的超卖、库存锁定不释放、消息丢失、重复扣减库存等核心问题
后端
XuanRanDev12 分钟前
【编程语言】Kotlin快速入门 - 泛型
开发语言·kotlin
普通网友13 分钟前
Android kotlin Jetpack mvvm 项目
android·开发语言·kotlin
木易 士心14 分钟前
Go、Rust、Kotlin、Python 与 Java 从性能到生态,全面解读五大主流编程语言
java·golang·rust
Crogin15 分钟前
快速简单入门Kotlin——基础语法(第一天)
android·开发语言·kotlin