Oj.Nbdp.Net 初赛题库 问题 状态 排名 团队 题解 课程 题目描述 感应门会在有人经过的时候自动打开,等待 x 秒后自动关闭。如果在门打开的时候有人通过,那么等待时间会被重置,重新计算 x 秒后再关闭。 给定一段时间内通过感应门的记录,请计算感应门一共开放了多少时间。 输入 第一行:两个正整数 n 与 x , n 表示通过感应门的人数, x 表示感应门的等待时间。 第二行: n 个正整数 t 1 , t 2 ,⋯, t n ,每个数字表达一个人通过感应门的时刻。 输出 样例输入输出 输入#1 复制 7 3 1 2 7 10 15 17 22 输出#1 复制 18 提示 对于 50% 的数据, 1≤n≤1000 ; 对于 100% 的数据, 1≤n≤ 10 5 , 1≤ t i ≤ 10 9 ,且 t 1 ≤ t 2 ≤ t 3 ≤⋯≤ t n 。思路
时间: 2024-04-01 07:36:52 浏览: 65
题目描述:
有一道门,门在有人经过的时候会自动打开,等待 x 秒后自动关闭。如果在门打开的时候有人通过,那么等待时间会被重置,重新计算 x 秒后再关闭。 现在给定一段时间内通过感应门的记录,请计算感应门一共开放了多少时间。
输入:
第一行:两个正整数 n 与 x ,n 表示通过感应门的人数,x 表示感应门的等待时间。
第二行:n 个正整数 t1,t2,⋯,tn,每个数字表达一个人通过感应门的时刻。
输出:
输出感应门一共开放的时间。
思路:
先设置两个变量,一个是门的状态变量 is_open,另一个是门的开放时长变量 open_time,将两个变量均初始化为 0。然后遍历通过感应门的记录,对于每个记录:
如果门是关闭的,将门的状态变量 is_open 设为 1,并将门的开放时长变量 open_time 加上感应门的等待时间 x。
如果门是开着的,将门的开放时长变量 open_time 加上感应门的等待时间 x 减去当前人通过感应门的时间与上一个人通过感应门的时间的差值。
最后输出门的开放时长变量 open_time 即可。
时间复杂度:O(n)
完整代码实现如下:
相关问题
Oj.Nbdp.Net 初赛题库 问题 状态 排名 团队 题解 课程 问题 D: 直线运输 题目 状态 题解 题目描述 给定一个正整数 n ,表示一个国家的城市数量。再给定一列整数 a 1 , a 2 ,⋯, a n ,表示每个城市生产或者消费物资的数量,正数表示生产数量,负数表示消费数量。输入数据保证生产总量和消费总量是相等的,即 a 1 + a 2 +⋯+ a n =0 。 这些物资可以从一个城市搬运到另一个城市,一次搬运必须在两个编号相邻的城市间进行,若搬运一个单位数量的物资到一个相邻的城市,将产生一个单位的工作量。请设计一个方案,使得所有物资都从生产城市搬运至消费城市,且每个消费城市需要的物资数量都能得到满足,且搬运的总工作量达到最小。 输入 第一行:单个整数表示 n 。 第二行: n 个整数表示 a 1 , a 2 ,⋯, a n 。 单个整数:表示最优运输方案产生的最少工作总量。 样例输入输出 输入#1 复制 4 -10 10 20 -20 输出#1 复制 30 提示 对于 30% 的数据, 1≤n≤10 ; 对于 60% 的数据, 1≤n≤100 ; 对于 100% 的数据, 1≤n≤100000 , −100000≤ a i ≤100000 ;
以下是这道题的 C++ 代码实现:
```cpp
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
int n;
cin >> n;
vector<int> a(n);
for (int i = 0; i < n; i++) {
cin >> a[i];
}
int left = 0, right = n - 1;
int ans = 0;
while (left < right) {
// 找到第一个需要消费的城市
while (a[left] >= 0) left++;
// 找到第一个需要生产的城市
while (a[right] <= 0) right--;
// 计算当前两个城市之间的搬运工作量
int t = min(-a[left], a[right]);
ans += t * (right - left);
a[left] += t;
a[right] -= t;
// 如果某个城市已经满足需求,则向前移动指针
if (a[left] == 0) left++;
if (a[right] == 0) right--;
}
cout << ans << endl;
return 0;
}
```
该算法的时间复杂度为 O(n),可以通过本题。
面对北航OJ平台上的AC编程挑战,如何高效地利用提供的题解和课程资源,系统学习并提高编程水平?
高效利用北航OJ平台的题解和课程资源进行AC编程学习,关键在于采取合适的策略和方法。首先,你需要对AC编程题目进行分类,例如算法、数据结构、数学问题等,然后选择适合自己当前水平的题目开始练习。在遇到难题时,仔细阅读题解文档和观看视频教程,理解解题思路和代码逻辑。对于难点,可以通过编写代码模板和注释来加深记忆。此外,编写自己的题解文档记录学习过程中的心得和错题,对于巩固知识点非常有帮助。尝试反复练习同一类型的题目,直到能够熟练掌握。最后,参考编程模板来练习不同编程语言的语法,通过不断的实践来提升编程水平。这些策略和方法都可以在《北航OJ通关指南:AC编程课程资源全面解析》一书中找到更详细的指导,该书将帮助你系统地学习编程知识,并通过AC编程平台的实战练习,逐步提高你的编程能力。
参考资源链接:[北航OJ通关指南:AC编程课程资源全面解析](https://wenku.csdn.net/doc/1zand6b32x?spm=1055.2569.3001.10343)
阅读全文