Rust 力扣 - 2841. 几乎唯一子数组的最大和

文章目录

题目描述

题解思路

我们遍历长度为k的窗口,用一个哈希表记录窗口内的所有元素(用来对窗口内元素去重),我们取哈希表中元素数量大于等于m的窗口总和的最大值

题解代码

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

impl Solution {
    pub fn max_sum(nums: Vec<i32>, m: i32, k: i32) -> i64 {
        let mut win = HashMap::new();

        let mut sum = 0;

        for i in 0..k as usize {
            win.insert(nums[i], i);
            sum += nums[i] as i64;
        }

        let mut ans = 0i64;

        if win.len() >= m as usize {
            ans = ans.max(sum);
        }

        for i in k as usize..nums.len() {
            if let Some(&start) = win.get(&nums[i-k as usize]) {
                if start == i - k as usize {
                    win.remove(&nums[i-k as usize]);
                }
            }

            win.insert(nums[i], i);

            sum += (nums[i] - nums[i-k as usize]) as i64;

            if win.len() >= m as usize {
                ans = ans.max(sum);
            }
        }

        ans
    }
}

题目链接

https://leetcode.cn/problems/maximum-sum-of-almost-unique-subarray/description/

相关推荐
spcier2 小时前
图论拓扑排序-Kahn 算法
算法·图论
知星小度S2 小时前
动态规划(一)——思想入门
算法·动态规划
ysa0510302 小时前
动态规划-逆向
c++·笔记·算法
燃于AC之乐2 小时前
我的算法修炼之路--7—— 手撕多重背包、贪心+差分,DFS,从数学建模到路径DP
c++·算法·数学建模·深度优先·动态规划(多重背包)·贪心 + 差分
Whisper_Sy2 小时前
Flutter for OpenHarmony移动数据使用监管助手App实战 - 网络状态实现
android·java·开发语言·javascript·网络·flutter·php
chinesegf2 小时前
文本嵌入模型的比较(一)
人工智能·算法·机器学习
Bony-2 小时前
Go语言垃圾回收机制详解与图解
开发语言·后端·golang
hmywillstronger2 小时前
【Rhino】【Python】 查询指定字段并cloud标注
开发语言·python
新缸中之脑2 小时前
Weave.js:开源实时白板库
开发语言·javascript·开源
我能坚持多久2 小时前
D16—C语言内功之数据在内存中的存储
c语言·开发语言