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

【LeetCode】每日一题 2024_11_1 超级饮料的最大强化能量(DP)

前言

每天和你一起刷 LeetCode 每日一题~

LeetCode 启动!

题目:超级饮料的最大强化能量

代码与解题思路

先读题:

题目给了两个数组,长度为 n,题目要求在 n 个小时内选择饮料,一个小时可以选一瓶,如果要切换饮料类型需要花费一个小时,这样就会少选一个饮料

有两个需要分类讨论的地方:

第一个饮料可以从 A 开始,也可以从 B 开始

后续的饮料有两种情况,1、选择喝下一瓶饮料,2、选择不喝,进行饮料类型的切换

像这样选与不选的题目,可以用动态规划来实现,设 dp[i][0] 表示在第 i 小时选择能量饮料 A 获得的最大强化能量,定义 dp[i][1] 表示在第 i 小时选择能量饮料 B 获得的最大强化能量

代码如下:

func maxEnergyBoost(energyDrinkA []int, energyDrinkB []int) int64 {
    n := len(energyDrinkA)
    dp := make([][2]int64, n+1)
    // 选 A 起手和选 B 起手两种情况
    dp[0][0], dp[0][1] = int64(energyDrinkA[0]), int64(energyDrinkB[0])
    for i := 1; i < n; i++ {
        dp[i][0] = max(dp[i-1][0]+int64(energyDrinkA[i]), dp[i-1][1])
        dp[i][1] = max(dp[i-1][1]+int64(energyDrinkB[i]), dp[i-1][0])
    }
    return max(dp[n-1][0], dp[n-1][1])
}

代码解释:

dp[i][0] = max(dp[i-1][0]+int64(energyDrinkA[i]), dp[i-1][1]) 中,dp[i-1][0]+int64(energyDrinkA[i]) 表示的就是继续选同一个类型的饮料,而 dp[i-1][1] 代表的是,选择从另一个类型的饮料转换到当前类型

举个例子,看示例二,类型 A 初始是 4,类型 B 初始是 1,第二瓶饮料的能量都是 1,那第二轮选择类型 B 的最大能量就是:第一轮先选 A,第二轮转换成 B,即代码中的 dp[i-1][0]。这样就能获得 4 点能量,如果两轮都选类型 B 只有 2 点能量

每天进步一点点,我们明天不见不散~

可以和我刷一辈子的每日一题吗?
一题一题,积累起来就是一辈子。


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

相关文章:

  • 又一次安装autoware.universe的过程
  • Android 使用ninja加速编译的方法
  • 服务器新建用户
  • 适用于 c++ 的 wxWidgets框架源码编译SDK-windows篇
  • Vue2指令原理手写
  • Android:ViewPaper动态添加移除第一页
  • 【实战篇】requests库 - 有道云翻译爬虫 【附:代理IP的使用】
  • brew 下载过慢, 切换使用国内源
  • Python小白学习教程从入门到入坑------第二十四课 继承(语法进阶)
  • 深度学习案例:一步步搭建多层神经网络以及应用
  • 基于向量检索的RAG大模型
  • 探索设计模式:命令模式
  • 第三十二章 Vue组件分类及存放位置
  • 本质矩阵分解计算Rt
  • 宝塔FTP服务配置结合内网穿透实现安全便捷的远程文件管理和传输
  • 广东网站设计提升你网站在搜索引擎中的排名
  • 搭建支持国密GmSSL的Nginx环境
  • 【AI+教育】一些记录@2024.11.04
  • latex中公式之间的省略号
  • C++ 内存对齐:alignas 与 alignof
  • 基于Matlab 模拟停车位管理系统【源码 GUI】
  • Selenium的下载及chrome环境搭建
  • git入门教程14:Git与其他工具的集成
  • 构造有向(无向)加权图
  • 机器学习算法之回归算法
  • 来康生命科技有限公司心率监测解决方案在健身房与康养机构的应用探索