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

Leetcode 3413. Maximum Coins From K Consecutive Bags

  • Leetcode 3413. Maximum Coins From K Consecutive Bags
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3413. Maximum Coins From K Consecutive Bags

1. 解题思路

这一题的话思路上整体上就是一个遍历,显然,要获得最大的coin,其选取的范围的必然满足下述两种情况之一:

  1. 其起始位置刚好位于某个bag区间的起始位置;
  2. 其终止位置刚好位于某个bag区间的终点位置;

因此,我们只需要将所有的bag区间进行排序,依次考察以下每一段区间作为起始位置和终止位置时其能够获得的coin的数目,然后从中选出最大值即可。

而给定某一个区间作为起始/终止位置之后,我们就可以通过二分查找快速定位到其终止/起始位置所处的区间,然后通过累积数组即可快速求得该区间内的所有的coin的数目。

2. 代码实现

给出python代码实现如下:

class Solution:def maximumCoins(self, coins: List[List[int]], k: int) -> int:n = len(coins)coins = sorted(coins)cumsums = [0 for _ in range(n+1)]for i, (l, r, c) in enumerate(coins):cumsums[i+1] = cumsums[i] + (r-l+1) * cans = 0for i, (l, r, c) in enumerate(coins):# start from lj = bisect.bisect_left(coins, [l+k, l+k, 0])if coins[j-1][1] < l+k:ans = max(ans, cumsums[j]-cumsums[i])else:ans = max(ans, cumsums[j-1]-cumsums[i] + (l+k - coins[j-1][0]) * coins[j-1][2])# end by rj = bisect.bisect_left(coins, [r-k+1, r-k+1, 0])if j > i:ans = max(ans, k * coins[i][2])elif j == 0 or coins[j-1][1] <= r-k:ans = max(ans, cumsums[i+1]-cumsums[j])else:ans = max(ans, cumsums[i+1]-cumsums[j] + (coins[j-1][1]-(r-k)) * coins[j-1][2])return ans

提交代码评测得到:耗时855ms,占用内存70.6MB。

http://www.lryc.cn/news/517761.html

相关文章:

  • MakeFile使用指南
  • 矩阵碰一碰发视频的视频剪辑功能源码搭建,支持OEM
  • VB.NET CRC32 校验
  • 冒充者综合征上线了
  • 【大模型】百度千帆大模型对接LangChain使用详解
  • Redis相关面试
  • 使用强化学习训练神经网络玩俄罗斯方块
  • java中的日期处理:只显示日期,不显示时间的两种处理方式
  • 腾讯云AI代码助手编程挑战赛——贪吃蛇小游戏
  • 水水水水水
  • Spring整合SpringMVC
  • 【Rust自学】10.4. trait Pt.2:trait作为参数和返回类型、trait bound
  • 嵌入式系统 (2.嵌入式硬件系统基础)
  • Linux 下 Vim 环境安装踩坑问题汇总及解决方法(重置版)
  • OpenAI 故障复盘 - 阿里云容器服务与可观测产品如何保障大规模 K8s 集群稳定性
  • 安卓触摸对焦
  • jupyter出现“.ipynb appears to have died. It will restart automatically.”解决方法
  • 20250108-实验+神经网络
  • 【权限管理】CAS(Central Authentication Service)
  • Golang笔记:使用net包进行TCP监听回环测试
  • 《浮岛风云》V1.0中文学习版
  • Day10——爬虫
  • 10. C语言 函数详解
  • NRC优先级中比较特殊的—NRC0x13和NRC0x31
  • ref() 和 reactive() 区别
  • 深度学习与计算机视觉 (博士)
  • Sprint Boot教程之五十:Spring Boot JpaRepository 示例
  • NaVILA:用于足式机器人导航的VLA模型
  • 大语言模型提示技巧(七)-扩展
  • 基类指针指向派生类对象,基类指针的首地址永远指向子类从基类继承的基类首地址