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

前言

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

LeetCode 启动!

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

代码与解题思路

先读题:

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

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

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

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

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

代码如下:

go 复制代码
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 点能量

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

可以和我刷一辈子的每日一题吗?

一题一题,积累起来就是一辈子。

相关推荐
别或许几秒前
2、高数----数列极限(知识总结)
算法
汀、人工智能7 分钟前
[特殊字符] 第78课:乘积最大子数组
数据结构·算法·数据库架构·数组·前缀积·乘积最大子数组
tankeven8 分钟前
HJ168 小红的字符串
c++·算法
数据知道10 分钟前
claw-code 源码分析:cargo 视角的 definitive runtime——会话、压缩、MCP、提示构造如何落到系统语言?
算法·ai·claude code·claw code
汀、人工智能13 分钟前
[特殊字符] 第41课:翻转二叉树
数据结构·算法·数据库架构·图论·bfs·翻转二叉树
2301_8227032014 分钟前
大学生体质健康测试全景测绘台:基于鸿蒙Flutter的多维数据可视化与状态管理响应架构
算法·flutter·信息可视化·架构·开源·harmonyos·鸿蒙
鲸渔15 分钟前
【C++ 输入输出】cin、cout、cerr 与格式化输出
开发语言·c++·算法
汀、人工智能15 分钟前
[特殊字符] 第46课:验证二叉搜索树
数据结构·算法·数据库架构·图论·bfs·验证二叉搜索树
靠沿20 分钟前
【递归、搜索与回溯算法】专题三——穷举vs暴搜vs深搜vs回溯vs剪枝
算法·机器学习·剪枝
香蕉鼠片20 分钟前
排序算法C++
c++·算法·排序算法