题目连接

http://acm.hdu.edu.cn/showproblem.php?pid=2094

产生冠军

Description

有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛。
球赛的规则如下:
如果A打败了B,B又打败了C,而A与C之间没有进行过比赛,那么就认定,A一定能打败C。
如果A打败了B,B又打败了C,而且,C又打败了A,那么A、B、C三者都不可能成为冠军。
根据这个规则,无需循环较量,或许就能确定冠军。你的任务就是面对一群比赛选手,在经过了若干场撕杀之后,确定是否已经实际上产生了冠军。

Input

输入含有一些选手群,每群选手都以一个整数n(n<1000)开头,后跟n对选手的比赛结果,比赛结果以一对选手名字(中间隔一空格)表示,前者战胜后者。如果n为0,则表示输入结束。

Output

对于每个选手群,若你判断出产生了冠军,则在一行中输出“Yes”,否则在一行中输出“No”。

Sample Input

3
Alice Bob
Smith John
Alice Smith
5
a c
c d
d e
b e
a d
0

Sample Output

Yes
No

找入度为0的点吧,如果大于1则无法产生冠军。。

  1. #include<algorithm>
  2. #include<iostream>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cstdio>
  6. #include<vector>
  7. #include<string>
  8. #include<map>
  9. using std::cin;
  10. using std::cout;
  11. using std::endl;
  12. using std::find;
  13. using std::sort;
  14. using std::map;
  15. using std::pair;
  16. using std::string;
  17. using std::vector;
  18. using std::multimap;
  19. #define pb(e) push_back(e)
  20. #define sz(c) (int)(c).size()
  21. #define mp(a, b) make_pair(a, b)
  22. #define all(c) (c).begin(), (c).end()
  23. #define iter(c) decltype((c).begin())
  24. #define cls(arr,val) memset(arr,val,sizeof(arr))
  25. #define cpresent(c, e) (find(all(c), (e)) != (c).end())
  26. #define rep(i, n) for (int i = 0; i < (int)(n); i++)
  27. #define tr(c, i) for (iter(c) i = (c).begin(); i != (c).end(); ++i)
  28. const int N = ;
  29. typedef unsigned long long ull;
  30. struct TopSort {
  31. int k, inq[N];
  32. map<string, int> rec;
  33. inline void init() {
  34. k = ;
  35. rec.clear(), cls(inq, );
  36. }
  37. inline void built(int m) {
  38. int a;
  39. char str1[], str2[];
  40. rep(i, m) {
  41. scanf("%s %s", str1, str2);
  42. if (rec.find(str1) == rec.end()) rec[str1] = k++;
  43. if (rec.find(str2) == rec.end()) rec[str2] = k++;
  44. a = rec[str2];
  45. inq[a]++;
  46. }
  47. }
  48. inline void solve() {
  49. int ans = ;
  50. rep(i, sz(rec)) {
  51. if (!inq[i]) ans++;
  52. }
  53. puts(ans == ? "Yes" : "No");
  54. }
  55. }work;
  56. int main() {
  57. #ifdef LOCAL
  58. freopen("in.txt", "r", stdin);
  59. freopen("out.txt", "w+", stdout);
  60. #endif
  61. int n;
  62. while (~scanf("%d", &n) && n) {
  63. work.init();
  64. work.built(n);
  65. work.solve();
  66. }
  67. return ;
  68. }

hdu 2094 产生冠军的更多相关文章

  1. 题解报告:hdu 2094 产生冠军

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2094 Problem Description 有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打 ...

  2. [HDU] 2094 产生冠军(拓扑排序+map)

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=2094 注意每组数据处理前,map要清空. #include<cstdio> #includ ...

  3. HDU 2094 产生冠军 (map容器)

    title: 产生冠军 杭电 2094 tags: [acm,stl] 题目链接 Problem Description 有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛. 球赛的规则 ...

  4. hdu 2094 产生冠军(拓扑排序)

    产生冠军 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  5. HDU 2094 产生冠军(半拓扑排序+map)

    产生冠军 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  6. hdu 2094 产生冠军(STL,set)

    题目 //把所有的出现的名字开始默认都为冠军(1),然后输了的置为0,表示不为冠军,最后统计不为0的, //当有且只有一个不为0的,这个就为冠军,否则,不能产生冠军. //以上思路来自别人的博客.. ...

  7. [HDU] 2094 产生冠军(拓扑排序+map)

    产生冠军 Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submissi ...

  8. HDU 2094 产生冠军 dfs加map容器

    解题报告:有一群人在打乒乓球比赛,需要在这一群人里面选出一个冠军,现在规定,若a赢了b,b又赢了c那么如果a与c没有比赛的话,就默认a赢了c,而如果c赢了a的话,则这三个人里面选不出冠军,还有就是如果 ...

  9. HDU 2094 产生冠军(STL map)

    产生冠军 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

随机推荐

  1. url 参数的加号变成空格处理

    今天在调试客户端向服务器传递参数时,参数中的“+”全部变成了空格,原因是URL中默认的将“+”号转义了. 解决方法如下: 方法一.修改客户端 将客户端带“+”的参数中的“+”全部替换为‍“2B%”,这 ...

  2. MySQL的体系结构

    因为MySQL采用的是客户机/服务器体系结构,所以你在使用MySQL存取数据时,必须至少使用两个或者说两类程序: 一个位于存放您的数据的主机上的程序 ----数据库服务器.数据库服务器监听从网络上传过 ...

  3. asp.net(c#)中如何在前端用js写条件查询,且不用调用存储过程

    前端页面(源): <dx:ASPxButton ID="ASPxButton_Select" runat="server" Text="查询&q ...

  4. JavaScript之数组循环 forEach 循环输出数组元素

    var arrayAll = []; arrayAll.push(1); arrayAll.push(2); arrayAll[arrayAll.length] = 3; arrayAll[array ...

  5. JS跳转到顶部的方法

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>J ...

  6. 安装npm

    npm是nodejs官方未nodejs定制的一个工具,是Node.js的包管理器,是Node Packaged Modules的简称,通过npm可以下载安装nodejs的模块包,nodejs有很多优秀 ...

  7. Glassfish数据源配置详解

    本文环境: Win2003 + myeclipse6.01 + sqlserver2000(sp4) 1. 安装glassfish——启动,在管理控制台下配置如下 首先配置连接池——大家把sqlser ...

  8. Spring与Quartz的整合实现定时任务调度

    摘自: http://kevin19900306.iteye.com/blog/1397744 最近在研究Spring中的定时任务功能,最好的办法当然是使用Quartz来实现.对于一个新手来说,花了我 ...

  9. webserver 发布问题

    1:web.config  <system.web>     <compilation debug="true" targetFramework="4. ...

  10. CSS设计之页面滚动条出现时防止页面跳动的方法

    一.水平居中布局与滚动条跳动的千年难题 当前web届,绝大多数的页面间布局都是水平居中布局,主体定个宽度,然后margin: 0 auto的节奏~ 例如,大淘宝的首页: 然而,这种布局有一个存在一个影 ...