再一次感觉网络流太神奇了qwq
题目链接:[星际转移问题](P4009 汽车加油行驶问题 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn))
受到之前那道[汽车加油行驶问题](P4009 汽车加油行驶问题 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn))按汽油剩余量建图的启发,这题自然而然的就想到了按时间建图,但是怎么按时间建图又成了一个难点.
首先判断是否有解,地球与月亮联通时必定有解. 这一步可以用并查集来判断
DSU dsu(n + 5);
for (int i = 1; i <= m; ++ i) {
for (auto &x : s[i]) cin >> x, ++ x;
for (int j = 0; j < k - 1; ++ j) dsu.merge(s[i][j], s[i][j + 1]);
}
if (dsu.find(0) != dsu.find(1)) {
cout << 0 << '\n';
return 0;
}
由于数据范围很小,我们可以枚举时间,然后跑最大流看是否等于总人数 K K K
本题的所有角色编号
-
源点: S S S
-
汇点: T T T
-
地球: 1 1 1
-
月球: 0 0 0
-
空间站: 0 ∽ n + 1 0 \backsim n+1 0∽n+1 ( ( (默认地球和月球也是空间站 ) ) )
-
太空船: n + 2 ∽ n + 1 + m n+2 \backsim n+1+m n+2∽n+1+m
所以除开源汇点外,节点个数 c n t cnt cnt为 n + m + 2 n+m+2 n+m+2,对于时间 T T T对应的节点编号为 i n d e x + T × ( n + m + 2 ) index+T \times (n+m+2)