提莫攻击 ---- 模拟算法

题目链接

题目:

分析:

  • 如果两次攻击的时间差是>=中毒的持续时间duration, 那么第一次攻击的中毒时间就是duration
  • 如果两次攻击的时间差是< 中毒的持续时间duration, 那么第一次攻击的持续时间就是这个时间差
  • 假设攻击了n次, 那么我们从第一次攻击开始计算时间差, 那么当我们算到最后一次时, 计算的是前面的n-1次的时间, 那么最后一次攻击, 中毒时间肯定是duration, 所以我们计算结果时, 要加上duration

代码:

java 复制代码
class Solution {
    public int findPoisonedDuration(int[] timeSeries, int duration) {
        int ret = 0;
        for(int i = 1; i < timeSeries.length; i++){
            if(timeSeries[i] - timeSeries[i-1] >= duration){
                ret += duration;
            }else{
                ret += timeSeries[i] - timeSeries[i-1];
            }
        }
        return ret + duration;
    }
}
相关推荐
Sirius Wu26 分钟前
Maven环境如何正确配置
java·maven
健康平安的活着1 小时前
java之 junit4单元测试Mockito的使用
java·开发语言·单元测试
No0d1es1 小时前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
Java小白程序员2 小时前
Spring Framework :IoC 容器的原理与实践
java·后端·spring
xuTao6672 小时前
Easy Rules 规则引擎详解
java·easy rules
m0_480502643 小时前
Rust 入门 KV存储HashMap (十七)
java·开发语言·rust
大阳1233 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
杨DaB3 小时前
【SpringBoot】Swagger 接口工具
java·spring boot·后端·restful·swagger
YA3333 小时前
java基础(九)sql基础及索引
java·开发语言·sql
Swift社区4 小时前
Swift 实战:实现一个简化版的 Twitter(LeetCode 355)
leetcode·swift·twitter