Leetcode每日一练--40

3147. 从魔法师身上吸取的最大能量

已解答

难度:中等

提示

在神秘的地牢中,n 个魔法师站成一排。每个魔法师都拥有一个属性,这个属性可以给你提供能量。有些魔法师可能会给你负能量,即从你身上吸取能量。

你被施加了一种诅咒,当你从魔法师 i 处吸收能量后,你将被立即传送到魔法师 (i + k) 处。这一过程将重复进行,直到你到达一个不存在 (i + k) 的魔法师为止。

换句话说,你将选择一个起点,然后以 k 为间隔跳跃,直到到达魔法师序列的末端,在过程中吸收所有的能量

给定一个数组 energy 和一个整数k,返回你能获得的最大能量。

示例 1:

输入: energy = [5,2,-10,-5,1], k = 3

输出: 3

**解释:**可以从魔法师 1 开始,吸收能量 2 + 1 = 3。

示例 2:

输入: energy = [-2,-3,-1], k = 2

输出: -1

**解释:**可以从魔法师 2 开始,吸收能量 -1。

提示:

  • 1 <= energy.length <= 10^5
  • -1000 <= energy[i] <= 1000
  • 1 <= k <= energy.length - 1

代码

cpp 复制代码
#include <stdlib.h>
#include <limits.h>

int maximumEnergy(int* energy, int energySize, int k) {
    int* dp = (int*)calloc(k, sizeof(int));  // 存储各链当前后缀和
    int max_energy = INT_MIN;  // 初始化为最小整数

    // 倒序遍历(关键优化点)
    for (int i = energySize - 1; i >= 0; i--) {
        int r = i % k;
        dp[r] = energy[i] + dp[r];  // 更新当前链后缀和
        if (dp[r] > max_energy) {
            max_energy = dp[r];  // 实时更新最大值
        }
    }

    free(dp);
    return max_energy;
}
相关推荐
西西弟3 小时前
常见排序算法集合(数据结构)
数据结构·算法·排序算法
Yzzz-F3 小时前
[模板]Nim博弈
算法
小龙报3 小时前
【数据结构与算法】栈和队列的综合应用:1.用栈实现队列 2.用队列实现栈 3.设计循环队列
c语言·数据结构·数据库·c++·redis·算法·缓存
重生之我是Java开发战士3 小时前
【广度优先搜索】队列:N叉树的层序遍历,二叉树的锯齿形层序遍历,二叉树的最大宽度,在每个树行中找最大值
数据结构·算法·leetcode·广度优先
qq_416018724 小时前
移动平台C++开发指南
开发语言·c++·算法
王璐WL4 小时前
【C++】string的经典算法题
开发语言·c++·算法
闻缺陷则喜何志丹4 小时前
【动态规划】P8591 『JROI-8』颅脑损伤 2.0|普及+
c++·算法·动态规划·洛谷
阿贵---4 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
倾心琴心4 小时前
【agent辅助pcb routing coding学习】实践7 length matching 算法学习
学习·算法·agent·pcb·routing
y = xⁿ4 小时前
【LeetCodehot100】T114:二叉树展开为链表 T105:从前序与中序遍历构造二叉树
java·算法·链表