题目名称 | 638. 摔跤 |
---|---|
输入输出 | rassle.in/out |
难度等级 | ★☆ |
时间限制 | 1000 ms (1 s) |
内存限制 | 128 MiB |
测试数据 | 10 |
题目来源 | 王者自由 于2012-02-16加入 |
开放分组 | 全部用户 |
提交状态 | |
分类标签 | |
分享题解 |
通过:11, 提交:58, 通过率:18.97% | ||||
belong.zmx | 100 | 0.009 s | 0.55 MiB | C++ |
QhelDIV | 100 | 0.010 s | 0.66 MiB | C++ |
MistyEye | 100 | 0.013 s | 0.51 MiB | C++ |
Citron酱 | 100 | 0.022 s | 0.55 MiB | C++ |
Oo湼鞶oO | 100 | 0.022 s | 0.55 MiB | C++ |
Makazeu | 100 | 0.023 s | 0.49 MiB | C++ |
201101 | 100 | 0.033 s | 0.41 MiB | C++ |
苏轼 | 100 | 0.099 s | 1.19 MiB | C++ |
Czb。 | 100 | 0.106 s | 0.14 MiB | C++ |
王者自由 | 100 | 0.278 s | 2.64 MiB | C++ |
关于 摔跤 的近10条评论(全部评论) |
---|
【问题描述】
有两种类型的职业摔跤手:一种是“好选手”,另一种是“差选手”。对于任何一对职业摔跤手来说,他们中可能有、也可能没有比赛。假定有 n 位职业摔跤手,并且有一份清单,上面列出了 r 对参加比赛的摔跤手。写一个程序,它能够确定是否可能指定某些摔跤手为好选手,而将余下的摔跤手指定为坏选手,从而使得每一场比赛都是在一个好选手与一个差选手之间进行。如果有可能做出这样的指定,你的程序就应该将它产生出来,否则输出无解“No”。
【输入格式】
第1行有三个整数n,r。n是职业摔跤手的数量,r是比赛场数,它们之间用一个空格隔开。
接下来的r行,每行用两个数V1,V2表示V1号摔跤手与V2号摔跤手比赛,选手从1开始编号。
【输出格式】
输出有两行,第一行“好选手”的编号,第二行为“差选手”的编号,编号之间用一个空格隔开。
注意:为了鼓励选手,使输出答案唯一,请尽量多的将选手设为“好选手”,并且在可行条件下选择编号小的选手为“好选手”。
如果无解,则输出一行“No”。
【输入输出样例】
rassle.in 4 4 1 2 1 4 2 3 3 4
rassle.out 1 3 2 4
【数据范围】
n<=10000, r<=10000