HDU2094(产生冠军)题解

以防万一,题目原文和链接均附在文末。那么先是题目分析:

【一句话题意】

根据给定现有比赛结果推断分析冠军。(这描述...我建议还是看题吧,题不长)

【题目分析】

给出的数据是每两个选手之间的关♂系,于是以为是简单链表,后来感觉是并查集,再后来才发现都不科学。于是换了一个特别科学普通简单粗暴可爱的方法。
在说方法之前,我想吐槽几句。这道题似乎不够严谨。数据里如果有一组是a>b;b>c;c>a;d>e的话,这将分为两个不相关的组合。这种情况我感觉应该输出的是No(两组人之前根本没有比赛,没办法知道d是不是可以打败abc成为冠军)。而实际上输出的是Yes。所以。。。。。。。。感觉不科学吧。。

【算法流程】

列名单,塞人员:
实际上就是把所有人名都列出来,从来没赢过的摔倒,赢过并且输过的摔掉。剩下的如果只有一个那就是冠军,如果不止一个就不是了。
简单优化:
与其列出所有人名然后筛选出赢过的,还不如直接只给赢过的列表。那么我们需要两个表,一个放赢家(只要赢过都算),一个放输家(只要输过的就算)。接下来拿赢家中的每一个对象在输家中找,如果找到就可以摔掉了。最后剩下的就是超级大赢家了。当然,为了去重,我们选择使用STL容器中的set集合处理去重。
STL:SET(std::set):

  • 初始化创建:set<string> loserList;
  • 清空元素:loserList.clear();
  • 在集合中插入:loserList.insert(loser);
  • 查找在集合中是否存在:loserList.find(*winnerIter)==loserList.end()//则不存在

这些东西列出来供尚未接触STL的人参考
从未接触过std::set的话,更多相关参见http://www.cplusplus.com/reference/set/set/
从未接触过STL的话,请复习cpp。

#include <iostream>
#include <string>
#include <algorithm>
#include <set>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h> #define each(i,n) (int i=1;i<=(n);++i) using namespace std; int main() { set<string> winnerList;
set<string> loserList;
string winner,loser;
int dataCount, flag; while(scanf("%d",&dataCount)!=EOF){
if (dataCount == ) break;
winnerList.clear();
loserList.clear();
while(dataCount--){
cin>>winner>>loser;
winnerList.insert(winner);
loserList.insert(loser);
}
flag = ;
set<string>::iterator winnerIter=winnerList.begin();
for(;winnerIter!=winnerList.end();winnerIter++) {
if (loserList.find(*winnerIter)==loserList.end()){
//cout<<"["<<*winnerIter<<endl;本来以为需要输出赢家是谁呢。。。
++flag;
//break;
}
}
if (flag == ) {
cout<<"Yes"<<endl;
} else {
cout<<"No"<<endl;
}
}
}
/*
TestData(IN)
3
Alice Bob
Smith John
Alice Smith
5
a c
c d
d e
b e
a d
0
TestData(OUT)
Yes
No
*/

题目链接:(HDU 2094)产生冠军

题目属性:脑筋急转弯(有说是并查集的,还有说是拓扑排序的,我刚开始还以为是单链表,嘛,管他呢。。),STL应用练习(可以当应用练习吧。。)
相关题目:1342、1361、1370、1506、1577、1597、1702、1716、1727(并非都是脑筋急转弯)
题目原文:
【Desc】有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛。
球赛的规则如下:
如果A打败了B,B又打败了C,而A与C之间没有进行过比赛,那么就认定,A一定能打败C。
如果A打败了B,B又打败了C,而且,C又打败了A,那么A、B、C三者都不可能成为冠军。
根据这个规则,无需循环较量,或许就能确定冠军。你的任务就是面对一群比赛选手,在经过了若干场撕杀之后,确定是否已经实际上产生了冠军。
【In】输入含有一些选手群,每群选手都以一个整数n(n<1000)开头,后跟n对选手的比赛结果,比赛结果以一对选手名字(中间隔一空格)表示,前者战胜后者。如果n为0,则表示输入结束。
【Out】输入含有一些选手群,每群选手都以一个整数n(n<1000)开头,后跟n对选手的比赛结果,比赛结果以一对选手名字(中间隔一空格)表示,前者战胜后者。如果n为0,则表示输入结束。
【SampIn/Out】参见代码下方的注释。

HDU2094(产生冠军)题解的更多相关文章

  1. HDU2094产生冠军 (拓扑排序)

    HDU2094产生冠军 Description 有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛. 球赛的规则如下: 如果A打败了B,B又打败了C,而A与C之间没有进行过比赛,那么就认 ...

  2. hdu2094产生冠军(思维题)

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

  3. hdu2094产生冠军[STL set]

    目录 题目地址 题干 代码和解释 参考 题目地址 hdu2094 题干 代码和解释 题意可以这样理解:一个人只要没输过就可以是冠军,如果没输过的人恰为一位,那就认他为冠军,若少于或多于一位,则判定没有 ...

  4. hdu2094—看似拓扑实际上是一道思维题

    HDU2094  产生冠军 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2094 题意:中文题,就不解释了.题意已经非常清楚了. 这道题的看起来像是一 ...

  5. hdu 5774 Where Amazing Happens 水题

    Where Amazing Happens 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5774 Description As the premie ...

  6. (set)产生冠军 hdu2094

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

  7. 产生冠军(hdu2094)

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

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

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

  9. BZOJ1934:[SHOI2007]善意的投票 & BZOJ2768:[JLOI2010]冠军调查——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=1934 https://www.lydsy.com/JudgeOnline/problem.php? ...

随机推荐

  1. C# 枚举运用"位"操作和"或"操作

    定义: /// <summary> /// The js function type(the same as name). /// </summary> [Flags] pub ...

  2. linq读书笔记2-查询内存中的对象

    上次我们说到了linq对数组内容的检索,自.net2.0以后,泛型成了很常见的一种应用技术,linq对泛型的检索也提供了完善的支持 如对list类型的支持,范例如下: class Program    ...

  3. HDU 1194 - Beat the Spread!

    给两数之和和两数之差,求两数,两数还必须同奇偶 #include <iostream> using namespace std; int main() { int a,b,t; cin&g ...

  4. Android code wiki

    Android code wiki Tip1: 类的全局静态变量的使用,这样可以静态变量只分配一次内存,可以不通过类的对象也就是可以通过类名直接使用该变量.(使用场景:Request_Code ,Re ...

  5. VB.NET生成Excel,已存在提示框点否时报错

    如题 Exception from HRESULT: 0x800A03EC 最终没有好的解决方案,只好屏蔽掉 Try obook.SaveAs(excelSaveName) Catch ex As S ...

  6. Nginx 变量漫谈(五)

    前面在 (二) 中我们已经了解到变量值容器的生命期是与请求绑定的,但是我当时有意避开了“请求”的正式定义.大家应当一直默认这里的“请求”都是指客户端发起的 HTTP 请求.其实在 Nginx 世界里有 ...

  7. Cacti 是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具

    Cacti 是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具. mysqlreport是mysql性能监测时最常用的工具,对了解mysql运行状态和配置调整都有很大 ...

  8. mini2440 uboot使用nfs方式引导内核,文件系统

    mini2440 uboot使用nfs方式引导内核,文件系统 成于坚持,败于止步 看了一段时间的u-boot了,到今天才真正完全实现u-boot引导内核和文件系统,顺利开机,在此记录完整过程 1.首先 ...

  9. Linux查看物理CPU个数、核数、逻辑CPU个数 (转)

    # 总核数 = 物理CPU个数 X 每颗物理CPU的核数 # 总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU的核数 X 超线程数 # 查看物理CPU个数 cat /proc/cpuinfo| ...

  10. IP地址分类与识别错误

    //描述:  请解析IP地址和对应的掩码,进行分类识别.要求按照A/B/C/D/E类地址归类,不合法的地址和掩码单独归类. //所有的IP地址划分为 A,B,C,D,E五类 //A类地址1.0.0.0 ...