题目描述
流浪地球计划在赤道上均匀部署了 NNN 个转向发动机,按位置顺序编号为 0∽N−10 \backsim N-10∽N−1。
-
初始状态下所有的发动机都是未启动状态;
-
发动机起动的方式分为“手动启动"和“关联启动"两种方式;
-
如果在时刻1一个发动机被启动,下一个时刻2与之相邻的两个发动机就会被“关联启动”;
-
如果准备启动某个发动机时,它已经被启动了,则什么都不用做;
-
发动机 000 与发动机 0∽N0 \backsim N0∽N 是相邻;
地球联合政府准备挑选某些发动机在某些时刻进行”手动启动”,当然最终所有的发动机都会被启动。哪些发动机最晚被启动呢?
输入描述
第一行两个数字NNN和EEE,中间有空格
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 行,每行都是两个数字 TTT 和 PPP ,中间有空格
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());
}
}