zoukankan      html  css  js  c++  java
  • hdu2094 stl之set的应用

    产生冠军

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 11807    Accepted Submission(s): 5485


    Problem 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
     
    Author
    qianneng
     
    Source
     
    本题正常看完之后感觉是拓扑排序,我开始的思路是先将字符串转化为整数,之后在进行拓扑排序找出出度为0的点,但是做完之后发现别人用的set一步就过去了
    解题思路就是首先定两个set变量,第一个变量存储所有成员,第二个变量只是存储失败的成员,如果第一个set的size等于第二个size加上1,那么就删除yes,否则输出no
    #include<stdio.h>
    #include<string.h>
    #include<iostream>
    #include<string>
    #include<set>
    #include<algorithm>
    using namespace std;
    char str1[1000],str2[1000];
    int main(){
        int n;
        
        while(scanf("%d",&n)!=EOF){
            if(n==0)
                break;
           memset(str1,0,sizeof(str1));
           memset(str2,0,sizeof(str2));
           set<string> q1,q2;
           for(int i=0;i<n;i++){
               scanf("%s %s",str1,str2);
    //            memset(str1,0,sizeof(str1));
    //            memset(str2,0,sizeof(str2));
                q1.insert(str1);
                q1.insert(str2);
                q2.insert(str2);
                  memset(str1,0,sizeof(str1));
                memset(str2,0,sizeof(str2));
           }
           int s1=q1.size();
           int s2=q2.size();
           if(s1==s2+1)
               printf("Yes
    ");
           else
    
               printf("No
    ");
    
        }
        return 0;
    }
  • 相关阅读:
    java 数据结构容器之HashSet
    java LinkedList模拟堆栈
    Java实现windows7标准型计算器
    Java迭代器注意事项
    (动态规划求解)聪明的kk
    三张图讲清楚Java中的方法的参数传递机制
    Java对象在内存中的表示
    两张内存变化图揭秘二维数组的初始化
    四张內存变化图揭秘引用类型数组的初始化
    三张內存变化图揭秘基本类型数组的初始化
  • 原文地址:https://www.cnblogs.com/13224ACMer/p/4792870.html
Copyright © 2011-2022 走看看