【C++刷题】力扣-#495-提莫攻击

ops/2024/10/31 19:36:05/

题目描述

在《英雄联盟》的世界中,有一个叫 “提莫” 的英雄。他的攻击可以让敌方英雄艾希(编者注:寒冰射手)进入中毒状态。
当提莫攻击艾希,艾希的中毒状态正好持续 duration 秒。 正式地讲,提莫在 t 发起攻击意味着艾希在时间区间 [t, t + duration - 1](含 t 和 t + duration - 1)处于中毒状态。如果提莫在中毒影响结束前再次攻击,中毒状态计时器将会重置 ,在新的攻击之后,中毒影响将会在 duration 秒后结束。
给你一个 非递减 的整数数组 timeSeries ,其中 timeSeries[i] 表示提莫在 timeSeries[i] 秒时对艾希发起攻击,以及一个表示中毒持续时间的整数 duration 。 返回艾希处于中毒状态的总秒数。

示例

示例 1

输入:timeSeries = [1,4], duration = 2
输出:4
解释:提莫攻击对艾希的影响如下:
● 第 1 秒,提莫攻击艾希并使其立即中毒。中毒状态会维持 2 秒,即第 1 秒和第 2 秒。
● 第 4 秒,提莫再次攻击艾希,艾希中毒状态又持续 2 秒,即第 4 秒和第 5 秒。
艾希在第 1、2、4、5 秒处于中毒状态,所以总中毒秒数是 4

示例 2

输入:timeSeries = [1,2], duration = 2
输出:3
解释:提莫攻击对艾希的影响如下:
● 第 1 秒,提莫攻击艾希并使其立即中毒。中毒状态会维持 2 秒,即第 1 秒和第 2 秒。
● 第 2 秒,提莫再次攻击艾希,并重置中毒计时器,艾希中毒状态需要持续 2 秒,即第 2 秒和第 3 秒。
艾希在第 1、2、3 秒处于中毒状态,所以总中毒秒数是 3

题解

  1. 初始化中毒时间:设置变量 totalSeconds 为 0,用于记录总的中毒秒数。
  2. 遍历攻击序列:从第一个攻击时间开始遍历 timeSeries。
    ○ 对于每次攻击,计算中毒状态的结束时间,即当前攻击时间加上 duration - 1。
    ○ 如果下一次攻击时间在当前中毒状态的持续时间内,则重置当前中毒状态的结束时间为下一次攻击时间加上 duration - 1。
    ○ 将每次中毒状态的持续时间加到 totalSeconds。
  3. 返回结果:返回 totalSeconds。

代码实现

int findPoisonedDuration(vector<int>& timeSeries, int duration) {int totalSeconds = 0;int n = timeSeries.size();for (int i = 0; i < n; ++i) {int start = timeSeries[i];int end = start + duration - 1;if (i == n - 1 || timeSeries[i + 1] > end) {// 如果是最后一次攻击或下一次攻击时间在当前中毒状态结束后totalSeconds += duration;} else {// 如果下一次攻击在当前中毒状态持续时间内totalSeconds += timeSeries[i + 1] - start;}}return totalSeconds;
}

复杂度分析

● 时间复杂度:O(n),其中 n 是攻击序列 timeSeries 的长度。我们需要遍历一次攻击序列。
● 空间复杂度:O(1),因为我们只使用了常数个额外变量。
这个算法的优势在于它直接遍历攻击序列并计算中毒状态的持续时间,不需要额外的数据结构。


http://www.ppmy.cn/ops/129940.html

相关文章

守护头顶安全——AI高空抛物监测,让悲剧不再重演

在城市的喧嚣中&#xff0c;我们享受着高楼林立带来的便捷与繁华&#xff0c;却往往忽视了那些隐藏在高空中的危险。近日&#xff0c;震惊全国的高空抛物死刑案件被最高院核准并执行。案件中被告人多次高空抛物的举动&#xff0c;夺去了无辜者的生命&#xff0c;也让自己付出了…

2024年10月23日Github流行趋势

项目名称&#xff1a;hiteshchoudhary / apihub 项目维护者&#xff1a;wajeshubham, atulbhatt-system32, jwala-anirudh, arnb-smnta, shrey-dadhaniya 项目介绍&#xff1a;您自己的API Hub&#xff0c;用于学习和掌握API交互。非常适合前端、移动开发人员和后端开发人员。 …

Bug | 项目中数据库查询问题

问题描述 理论上&#xff0c;点击查询后&#xff0c;表头应当显示中文。而不是上面的在数据库中的表头【如上图示】 正常点击查询后&#xff0c;如果没有输入值&#xff0c;应当是查询所有的信息。 原因分析&#xff1a; 这里是直接使用SELECT * 导致的。例如&#xff1a; S…

显示浏览器窗口的大小

html页面的代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><script src"https://apps.bdimg.com/li…

6.2 创建GDT表(2)

首先是 创建 include 文件夹&#xff0c; 创建了三个文件夹&#xff0c; cpu , include , cpu (include 下) 然后是 修改 cmakelist 接下来 是 创建 cpu.h&#xff0c; 关于 x86 cpu 相关的东西。 #ifndef CPU_H #define CPU_H#include "comm/types.h"#pragma pack(…

GPT论文整理提示词

论文阅读 指令1:粗读论文 请你阅读并理解这篇文献&#xff0c;然后将该篇文章的标题作为一级标题&#xff0c;将摘要和各个大标题作为二级标题&#xff0c;将小标题作为三级标题&#xff0c;将小标题下每一部分内容作为四级标题&#xff0c;给我以markdown的语言输出中文的翻…

【论文阅读】ESRGAN+

学习资料 论文题目&#xff1a;进一步改进增强型超分辨率生成对抗网络&#xff08;ESRGAN : FURTHER IMPROVING ENHANCED SUPER-RESOLUTION GENERATIVE ADVERSARIAL NETWORK&#xff09;论文地址&#xff1a;2001.08073代码&#xff1a;ncarraz/ESRGANplus&#xff1a; ICASSP …

网络自动化01:netmiko基础、netmiko简单demo

本系列应该是记录我在网络自动化中的学习、使用。具体更新多少期、什么频率都不太清楚。 同时本文的记录方式不会是那么的符合学习的思路&#xff0c;需要更加详细的内容建议阅读官方文档等。 本人学习的路径是基于九净老师的NetDevOps加油站&#xff0c;但本文有所简化&#x…