流浪地球 E100

题目描述

流浪地球计划在赤道上均匀部署了 NNN 个转向发动机,按位置顺序编号为 0∽N−10 \backsim N-10N1

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

  2. 发动机起动的方式分为“手动启动"和“关联启动"两种方式;

  3. 如果在时刻1一个发动机被启动,下一个时刻2与之相邻的两个发动机就会被“关联启动”;

  4. 如果准备启动某个发动机时,它已经被启动了,则什么都不用做;

  5. 发动机 000 与发动机 0∽N0 \backsim N0N 是相邻;

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

输入描述

第一行两个数字NNNEEE,中间有空格

NNN 代表部署发动机的总个数,EEE 代表计划手动启动的发动机总个数

  • 1<N<=1000,1<=E<=1000,E<=N1<N<=1000,1<=E<=1000,E<=N1<N<=1000,1<=E<=1000,E<=N

接下来共 EEE 行,每行都是两个数字 TTTPPP ,中间有空格

TTT 代表发动机的手动启动时刻, PPP 代表此发动机的位置编号。
0<=T<=N,0<=P<=N0<=T<=N,0<=P<=N0<=T<=N,0<=P<=N

输出描述

第一行一个数字 NNN ,以回车结束N代表最后被启动的发动机个数

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

示例1

输入

8 2
0 2
0 6

输出

2
0 4

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

示例2

82
01
17

输出

1
4

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

题解

主义如果本次启动的节点是 0 ,则本节点的下一个节点是 7 号节点。

源码Java

public class Earth {
	static int N = 0;
	public static void main(String[] args) {

		Scanner scanner = new Scanner(System.in);
		N = scanner.nextInt();
		int startCount = scanner.nextInt();
		Map<Integer, List<Integer>> map = new HashMap<>();
		for (int i = 0; i < startCount; i++) {
			int key = scanner.nextInt();
			List<Integer> orDefault = map.getOrDefault(key, new ArrayList<>());
			int e = scanner.nextInt();
			orDefault.add(e);
			map.put(key, orDefault);
		}
		boolean[] visited = new boolean[N];
		List<Integer> nextStartupList = map.get(0);
		int key = 0;
		while(nextStartupList.size() > 0) {
			/*
			StringBuilder sb = new StringBuilder();
			for (int i = 0; i < nextStartupList.size(); i++) {
				sb.append(nextStartupList.get(i) + " ");
			}
			System.out.println("当前启动" + sb.toString());
			*/
			// 瑕疵启动
			List<Integer> next = map.getOrDefault(key+1, new ArrayList<>());
			for (int i = 0; i < nextStartupList.size(); i++) {
				Integer i1 = nextStartupList.get(i);
				visited[i1] = true;
				int pre = ( i1 - 1 + N) % N ;
				int after = (i1 + 1) % N;
				// 如果未启动,加入下次启动
				if (!visited[pre] && !next.contains(pre)) {
					next.add(pre);
				}
				if (!visited[after] && !next.contains(after)) {
					next.add(after);
				}
			}
			if (next.size() == 0) {
				break;
			}
			key++;
			nextStartupList = next;
		}
		Collections.sort(nextStartupList);
		StringBuilder builder = new StringBuilder();
		for (int i = 0; i < nextStartupList.size(); i++) {
			builder.append(nextStartupList.get(i) + " ");
		}
		System.out.println(key);
		System.out.println(builder.toString().trim());
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

坚定的小辣鸡在努力

你的支持是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值