100274. 从魔法师身上吸取的最大能量
在神秘的地牢中,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 <= 105
-1000 <= energy[i] <= 1000
1 <= k <= energy.length - 1
思路1 模拟
时间复杂度On2
class Solution { public static int maximumEnergy(int[] energy, int k) { int[] record = new int[energy.length]; for(int i =0 ; i < energy.length ; i++){ int pos = i; while (pos < energy.length && pos >= 0) { record[i] += energy[pos]; pos += k; } } int res = Integer.MIN_VALUE; for(int i = 0 ; i < record.length ; i++){ res = Math.max(res, record[i]); } return res; } }
思路2
反向倒推,时间复杂度On
class Solution { public static int maximumEnergy(int[] energy, int k) { int[] result = new int[energy.length]; int res = Integer.MIN_VALUE; for(int i=energy.length-1;i>=0;i--){ if(i+k>=energy.length){ result[i] = energy[i]; } else{ result[i] = energy[i] + result[i+k]; } if(result[i]>res){ res = result[i]; } } return res; } }