当前位置: 首页 > article >正文

[LeetCode-Python版] 定长滑动窗口8——2461. 长度为 K 子数组中的最大和

题目

给你一个整数数组 nums 和一个整数 k 。请你从 nums 中满足下述条件的全部子数组中找出最大子数组和:

子数组的长度是 k,且
子数组中的所有元素 各不相同 。
返回满足题面要求的最大子数组和。如果不存在子数组满足这些条件,返回 0 。

子数组 是数组中一段连续非空的元素序列。

示例 1:
输入:nums = [1,5,4,2,9,9,9], k = 3
输出:15
解释:nums 中长度为 3 的子数组是:

  • [1,5,4] 满足全部条件,和为 10 。
  • [5,4,2] 满足全部条件,和为 11 。
  • [4,2,9] 满足全部条件,和为 15 。
  • [2,9,9] 不满足全部条件,因为元素 9 出现重复。
  • [9,9,9] 不满足全部条件,因为元素 9 出现重复。
    因为 15 是满足全部条件的所有子数组中的最大子数组和,所以返回 15 。

示例 2:
输入:nums = [4,4,4], k = 3
输出:0
解释:nums 中长度为 3 的子数组是:

  • [4,4,4] 不满足全部条件,因为元素 4 出现重复。
    因为不存在满足全部条件的子数组,所以返回 0 。

提示:

  • 1 <= k <= nums.length <= 105
  • 1 <= nums[i] <= 105

题目链接

我的思路

维护一个sub数组记录窗口内数字,用集合判断是否重复

思路不足
会超时

我的代码

class Solution:
    def maximumSubarraySum(self, nums: List[int], k: int) -> int:
        max_sub = 0
        sub = []

        for i,n in enumerate(nums):
            sub.append(n)
            if i < k-1:
                continue
            if len(set(sub)) == len(sub):
                max_sub = max(max_sub,sum(sub))
            sub.pop(0)
        return max_sub
       

题解思路

用哈希表

参考代码

class Solution:
    def maximumSubarraySum(self, nums: List[int], k: int) -> int:
        ms = 0
        cnt = Counter(nums[:k-1])
        s = sum(nums[:k-1])
        
        for i,o in zip(nums[k-1:],nums):
            cnt[i]+=1
            s+=i
            if len(cnt)==k:
                ms = max(ms,s)
            cnt[o]-=1
            if cnt[o]==0:
                del cnt[o]
            s-=o
        return ms 

http://www.kler.cn/a/449908.html

相关文章:

  • Selenium 和 Playwright两大框架的不同之处
  • Unity3D仿星露谷物语开发5之角色单例模式
  • 解析mysqlbinlog
  • 差分矩阵(Difference Matrix)与累计和矩阵(Running Sum Matrix)的概念与应用:中英双语
  • .NET Core 中使用 C# 获取Windows 和 Linux 环境兼容路径合并
  • UML图【重要】
  • Windows和Linux安全配置和加固
  • [Effective C++]条款38-39 复合和private继承
  • IT运维的365天--021 服务器上的dns设置后不起作用
  • aws(学习笔记第十九课) 使用ECS和Fargate进行容器开发
  • 云计算中的容器技术(如Docker)是什么?
  • 一些elasticsearch重要概念与配置参数
  • webview和H5来实现的android短视频(短剧)音视频播放依赖控件
  • 动手学深度学习11.2. 凸性-笔记练习(PyTorch)
  • 一篇文章学会HTML
  • 最适合智能体的身份认证技术:对比OpenID Connect、API keys、did:wba
  • 类class:继承类后同名方法是覆盖还是去哪了呢,类中this指向问题等
  • 汽车IVI中控开发入门及进阶(44):杰发科智能座舱芯片
  • 【CSS】优化动画性能
  • rk3568制冷项目驱动开发流程汇总(只适用于部分模块CIF DVP等,自用)
  • 【计算机视觉基础CV-图像分类】05 - 深入解析ResNet与GoogLeNet:从基础理论到实际应用
  • 【时间之外】IT人求职和创业应知【74】-运维机器人
  • 基于微信小程序的国产动漫论坛系统
  • css让按钮放在最右侧
  • 初学stm32 --- NVIC中断
  • logback日志控制台打印与写入文件