LeetCode第一天(495.提莫攻击)

题目:

在《英雄联盟》的世界中,有一个叫 "提莫" 的英雄。他的攻击可以让敌方英雄艾希(编者注:寒冰射手)进入中毒状态。

当提莫攻击艾希,艾希的中毒状态正好持续 duration 秒。

正式地讲,提莫在 t 发起攻击意味着艾希在时间区间 [t, t + duration - 1](含 tt + duration - 1)处于中毒状态。如果提莫在中毒影响结束 再次攻击,中毒状态计时器将会 重置 ,在新的攻击之后,中毒影响将会在 duration 秒后结束。

给你一个 非递减 的整数数组 timeSeries ,其中 timeSeries[i] 表示提莫在 timeSeries[i] 秒时对艾希发起攻击,以及一个表示中毒持续时间的整数 duration

返回艾希处于中毒状态的 秒数。

官解:

我们只需要对数组进行一次扫描就可以计算出总的中毒持续时间。我们记录艾希恢复为未中毒的起始时间 expired\textit{expired}expired,设艾希遭遇第 iii 次的攻击的时间为 timeSeriesi\textit{timeSeries}itimeSeriesi。当艾希遭遇第 iii 攻击时:

如果当前他正处于未中毒状态,则此时他的中毒持续时间应增加 duration\textit{duration}duration​,同时更新本次中毒结束时间 expired\textit{expired}expired​ 等于 timeSeriesi+duration\textit{timeSeries}i + \textit{duration}timeSeriesi+duration​;

如果当前他正处于中毒状态,由于中毒状态不可叠加,我们知道上次中毒后结束时间为 expired\textit{expired}expired​​,本次中毒后结束时间为 timeSeriesi+duration\textit{timeSeries}i + \textit{duration}timeSeriesi+duration​​,因此本次中毒增加的持续中毒时间为 timeSeriesi+duration−expired\textit{timeSeries}i + \textit{duration} -\textit{expired}timeSeriesi+duration−expired​​;

我们将每次中毒后增加的持续中毒时间相加即为总的持续中毒时间。

java 复制代码
class Solution {
    public int findPoisonedDuration(int[] timeSeries, int duration) {
        int sum = 0;
        int expired = 0;

        for(int i = 0;i < timeSeries.length;++i){
            if(timeSeries[i] >= expired){
                sum += duration;
            }else{
                sum += timeSeries[i] + duration - expired;
            }
            expired = timeSeries[i] + duration;
        }
        
        return sum;

    }
}
相关推荐
AKA__Zas2 分钟前
初识多线程plus(2.0)
java·开发语言·学习方法
无限码力3 分钟前
美团研发岗 5月9号笔试真题 - 正整数矩阵
算法·美团笔试真题·美团研发岗笔试真题·美团0509笔试真题
Smilecoc6 分钟前
决策树(二):决策树的划分选择
算法·决策树·机器学习
布朗克1689 分钟前
33 设计模式精讲
java·单例模式·设计模式
hetao173383717 分钟前
2026-05-25~06-11 hetao1733837 的刷题记录
c++·算法
cheems952720 分钟前
[算法手记] 滑动窗口最大值
算法
洛水水22 分钟前
【力扣100题】82.有效的括号
c++·算法·leetcode
XGeFei23 分钟前
时序算法 —— LSTM、ARIMA、随机森林
算法·随机森林·lstm
码语智行23 分钟前
基于word模板导出人员信息
java
西凉的悲伤32 分钟前
redis和数据库实现分布式锁
java·数据库·redis·分布式