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

【LeetCode】918. 环形子数组的最大和

1. 题目

在这里插入图片描述

2. 分析

单调队列的经典应用。

3. 代码

class Solution:def maxSubarraySumCircular(self, nums: List[int]) -> int:# 使用单调队列的解法# 转换为求区间长度不超过len(nums)内的最大和k = len(nums)nums = nums + nums# 求出前缀和prefixSum = [0] * len(nums) prefixSum[0] = nums[0]for i in range(1, len(nums)):prefixSum[i] = prefixSum[i-1] + nums[i]# 单调队列求出区间最大和que = [0] * (len(nums) + 1)# 关键点1:left 和 right的初始值为1left = 1right = 1res = nums[0]que[1]= 0 # 将nums的第一个元素放进去for i in range(1, len(nums)): # 遍历区间的每一个数# 更新队列while(left <= right and que[left] < i - k ):left += 1# 更新结果res = max(res, prefixSum[i] - prefixSum[que[left]])# 更新队列while( left <= right and prefixSum[que[right]] >= prefixSum[i]):right -= 1right += 1que[right] = iprint(res)return res

http://www.mrgr.cn/news/16233.html

相关文章:

  • 原来食物也可以治病 第一篇
  • SQL数据库教案(入门必备)
  • 持续集成与持续部署(CI/CD)的深入探讨
  • clerk中authenticateWithRedirect方法讲解
  • !!学习整理知识模块——关于【如何本地搭建Whisper语音识别模型】/请按需收藏!!
  • Java:时区的用法
  • AMD简介
  • 4.1(1) 图的存储结构-邻接矩阵-无权值
  • 学习之MySQL函数(字符串,数值,日期,流程)
  • 随笔九、SARADC按键程控测试
  • 从默默无名到销量激增,极越CEO哭了
  • Java基础(6)- Java代码笔记3
  • 基于django框架下个人着装助理系统/基于python的服装服装搭配系统
  • Excel 下载工具类
  • nacos集群部署和VIP部署
  • 2024最新最全:网络安全人士【必备的30个安全工具】
  • Linux文件和目录常用命令
  • Tomcat与Servlet加载问题
  • shell脚本编写注意事项
  • YOLOv9改进策略【模型轻量化】| 利用PP-LCnet改进RepNCSPELAN4