题目名称 | 891. 街道赛跑 |
---|---|
输入输出 | race3.in/out |
难度等级 | ★ |
时间限制 | 1000 ms (1 s) |
内存限制 | 128 MiB |
测试数据 | 11 |
题目来源 | sywgz 于2012-07-11加入 |
开放分组 | 全部用户 |
提交状态 | |
分类标签 | |
分享题解 |
通过:8, 提交:13, 通过率:61.54% | ||||
QILIN | 100 | 0.002 s | 0.30 MiB | C++ |
QWERTIer | 100 | 0.003 s | 0.31 MiB | C++ |
mikumikumi | 100 | 0.003 s | 0.32 MiB | C++ |
rewine | 100 | 0.003 s | 0.32 MiB | C++ |
cstdio | 100 | 0.005 s | 0.32 MiB | C++ |
xinging | 100 | 0.005 s | 0.35 MiB | C++ |
Ostmbh | 100 | 0.006 s | 0.29 MiB | C++ |
QhelDIV | 100 | 0.007 s | 3.33 MiB | C++ |
feng | 90 | 1.022 s | 0.18 MiB | Pascal |
cstdio | 72 | 0.004 s | 0.32 MiB | C++ |
关于 街道赛跑 的近10条评论(全部评论) | ||||
---|---|---|---|---|
回复 @HouJikan : 这是BFS好吗。。。
xinging
2015-02-25 20:20
4楼
| ||||
第一问就是求有向图的割顶。第二问是不是求无向图的割顶?
HouJikan
2014-09-04 22:14
3楼
| ||||
然后我就一头砸坑里了……= =
| ||||
很简单,但是有点小坑,注意不要踩..
QhelDIV
2013-02-25 17:31
1楼
|
描述
图一表示一次街道赛跑的跑道。可以看出有一些路口(用 0 到 N 的整数标号),和连接这些路口的箭头。路口 0 是跑道的起点,路口 N 是跑道的终点。箭头表示单行道。运动员们可以顺着街道从一个路口移动到另一个路口(只能按照箭头所指的方向)。当运动员处于路口位置时,他可以选择任意一条由这个路口引出的街道。
图一:有 10 个路口的街道
一个良好的跑道具有如下几个特点:
每一个路口都可以由起点到达。
从任意一个路口都可以到达终点。
终点不通往任何路口。
运动员不必经过所有的路口来完成比赛。有些路口却是选择任意一条路线都必须到达的(称为“不可避免”的)。在上面的例子中,这些路口是 0,3,6,9。对于给出的良好的跑道,你的程序要确定“不可避免”的路口的集合,不包括起点和终点。
假设比赛要分两天进行。为了达到这个目的,原来的跑道必须分为两个跑道,每天使用一个跑道。第一天,起点为路口 0,终点为一个“中间路口”;第二天,起点是那个中间路口,而终点为路口 N。对于给出的良好的跑道,你的程序要确定“中间路口”的集合。如果良好的跑道 C 可以被路口 S 分成两部分,这两部分都是良好的,并且 S 不同于起点也不同于终点,同时被分割的两个部分满足下列条件:(1)它们之间没有共同的街道(2)S 为它们唯一的公共点,并且 S 作为其中一个的终点和另外一个的起点。那么我们称 S 为“中间路口 ”。在例子中只有路口 3 是中间路口。
PROGRAM NAME: race3
INPUT FORMAT(file race3.in)
输入文件包括一个良好的跑道,最多有 50 个路口,100 条单行道。一共有 N+2 行,前面 N+1 行中第 i 行表示以 i-1 为起点的街道,每个数字表示一个终点。行末用 -2 作为结束。最后一行只有一个数字 -1。
OUTPUT FORMAT(file race3.out)
你的程序要有两行输出:
第一行包括:跑道中“不可避免的”路口的数量,接着是这些路口的序号,序号按照升序排列。
第二行包括:跑道中“中间路口”的数量,接着是这些路口的序号,序号按照升序排列。
SAMPLE INPUT (file race3.in)
1 2 -2
3 -2
3 -2
5 4 -2
6 4 -2
6 -2
7 8 -2
9 -2
5 9 -2
-2
-1
SAMPLE OUTPUT (file race3.out)
2 3 6
1 3