当前位置 博文首页 > Michael是个半路程序员:LeetCode 495. 提莫攻击

    Michael是个半路程序员:LeetCode 495. 提莫攻击

    作者:[db:作者] 时间:2021-08-21 22:19

    1. 题目

    在《英雄联盟》的世界中,有一个叫 “提莫” 的英雄,他的攻击可以让敌方英雄艾希(编者注:寒冰射手)进入中毒状态。现在,给出提莫对艾希的攻击时间序列和提莫攻击的中毒持续时间,你需要输出艾希的中毒状态总时长。

    你可以认为提莫在给定的时间点进行攻击,并立即使艾希处于中毒状态。

    示例1:
    输入: [1,4], 2
    输出: 4
    原因: 在第 1 秒开始时,提莫开始对艾希进行攻击并使其立即中毒。
    中毒状态会维持 2 秒钟,直到第 2 秒钟结束。
    在第 4 秒开始时,提莫再次攻击艾希,使得艾希获得另外 2 秒的中毒时间。
    所以最终输出 4 秒。
    
    示例2:
    输入: [1,2], 2
    输出: 3
    原因: 在第 1 秒开始时,提莫开始对艾希进行攻击并使其立即中毒。
    中毒状态会维持 2 秒钟,直到第 2 秒钟结束。
    但是在第 2 秒开始时,提莫再次攻击了已经处于中毒状态的艾希。
    由于中毒状态不可叠加,提莫在第 2 秒开始时的这次攻击会在第 3 秒钟结束。
    所以最终输出 3。
    
    注意:
    你可以假定时间序列数组的总长度不超过 10000。
    你可以假定提莫攻击时间序列中的数字和提莫攻击的中毒持续时间都是**非负**整数,并且不超过 10,000,000

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/teemo-attacking
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    2. 解题

    class Solution {
    public:
        int findPoisonedDuration(vector<int>& timeSeries, int duration) {
            int time = 0, endtime;
            for(int i = 0; i < timeSeries.size(); ++i)
            {
            	endtime = timeSeries[i] + duration;
            	if(i == timeSeries.size()-1 || endtime <= timeSeries[i+1])
    	        	time += duration;
    	        else
    	        	time += timeSeries[i+1]-timeSeries[i];
            }
            return time;
        }
    };
    

    在这里插入图片描述

    or

    class Solution {
    public:
        int findPoisonedDuration(vector<int>& timeSeries, int duration) {
            if(timeSeries.empty())
            	return 0;
            int time = 0;
            for(int i = 0; i < timeSeries.size()-1; ++i)
            	time += min(timeSeries[i+1]-timeSeries[i], duration);
            return time+duration;
        }
    };
    

    在这里插入图片描述

    cs