华为OD机试2025A卷 - 流浪地球(Java & Python& JS & C++ & C )

最新华为OD机试

真题目录:点击查看目录
华为OD面试真题精选:点击立即查看

题目描述

流浪地球计划在赤道上均匀部署了N个转向发动机,按位置顺序编号为0~N-1。

  1. 初始状态下所有的发动机都是未启动状态;
  2. 发动机启动的方式分为”手动启动"和”关联启动"两种方式;
  3. 如果在时刻1一个发动机被启动,下一个时刻2与之相邻的两个发动机就会被”关联启动”;
  4. 如果准备启动某个发动机时,它已经被启动了,则什么都不用做;
  5. 发动机0与发动机N-1是相邻的;

地球联合政府准备挑选某些发动机在某些时刻进行“手动启动”。当然最终所有的发动机都会被启动。

哪些发动机最晚被启动呢?

输入描述

  • 第一行两个数字N和E,中间有空格
    N代表部署发动机的总个数,E代表计划手动启动的发动机总个数
    1<N<=1000,1<=E<=1000,E<=N
  • 接下来共E行,每行都是两个数字T和P,中间有空格
    T代表发动机的手动启动时刻,P代表此发动机的位置编号。
    0<=T<=N.0<=P<N

输出描述

  • 第一行一个数字N,以回车结束
    N代表最后被启动的发动机个数
  • 第二行N个数字,中间有空格,以回车结束
    每个数字代表发动机的位置编号,从小到大排序

示例1

输入

8 2
0 2
0 6

输出

2
0 4

说明

8个发动机,时刻0启动2和6号发动机

示例2

输入:

8 2
0 0
1 7

输出:

1
4

说明

8个发动机,时刻0手动启动0,时刻1手动启动7.

解题思路

题目解析

  1. 初始状态:所有的发动机都是未启动状态。

  2. 启动方式

    • 手动启动:你可以在某个时刻手动启动指定位置的发动机。
    • 关联启动:如果一个发动机在时刻1被启动,那么它的相邻发动机(左右两个,位置编号上相邻)会在下一时刻(时刻2)被自动启动。
  3. 循环关系:发动机0和N-1是相邻的,这意味着整个发动机的排列是环形的。

  4. 发动机启动规则

    • 如果准备启动的发动机已经被启动,那么就不需要做任何操作。
    • 需要根据手动启动的时刻和位置,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值