1.题目
分值:100
题目描述
流浪地球计划在赤道上均匀部署了N个转向发动机,按位置顺序编号为0~N-1。
初始状态下所有的发动机都是未启动状态。
发动机启动的方式分为“手动启动”和“关联启动”两种方式如果在时刻1一个发动机被启动,下一个时刻 2与之相邻的两个发动机就会被“关联启动”。如果准备启动某个发动机时,它已经被启动了,则什么都不用做。发动机0与发动机 N-1是相邻的。
地球联合政府准备挑选某些发动机在某些时刻进行“手动启动”。当然最终所有的发动机都会被启动。哪些发动机最晚被启动呢?
输入描述:
第一行两个数字N和E,中间有空格。
N 代表部署发动机的总个数,E 代表计划手动启动的发动机总个数。
接下来共E行,每行都是两个数字T和P,中间有空格。
T 代表发动机的手动启动时刻,P 代表此发动机的位置编号。
输出描述:
第一行一个数字 N,以回车结束。
N 代表最后被启动的发动机个数。
第二行 N个数字,中间有空格,以回车结束。
每个数字代表发动机的位置编号,从小到大排序。
示例1
输入:
8 2
0 2
0 6
输出:
2
0 4
解释:
8 个发动机,时刻 0 启动 2 和 6 号发动机。
Tips:
1 < N ≤ 1000
1 ≤ E ≤ 1000,E ≤ N
0 ≤ T ≤ N
0 ≤ P < N
2.思路
该思路看了博客【华为OD机试真题】【2024年E卷】流浪地球-迭代&模拟(C++/Java/Python)_华为od流浪地球-CSDN博客的思路,代码也是,这里作为笔记用。后续会更新更快更节约空间的思路。
3.代码
代码如下:
if __name__ == '__main__':
maxs = 1005
n, e = map(int, input().split())
launch = [-1] * maxs
# 这里将手动启动的时间和位置放入launch
for _ in range(e):
t, p = map(int, input().split())
launch[p] = t
for timer in range(n + 1):
cnt = 0
for i in range(n):
if launch[i] == -1:
if (launch[(i + 1)%n] != -1 and launch[(i + 1)% n] < timer) or (launch[(i + n - 1)%n] != -1 and launch[(i + n - 1)%n] < timer):
launch[i] = timer
cnt += 1
elif launch[i] <= timer:
cnt += 1
if cnt == n:
nums = []
for i in range(n):
if launch[i] == timer:
nums.append(i)
print(len(nums))
print(" ".join(map(str,nums)))
break