F – 产生冠军(不使用拓扑排序)

yizhihongxing

题目描述

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

输入

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

输出

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

#include<iostream>
#include<string>
#include<cstring>
#include<set>
using namespace std;
int n;   //n组对决
/*将所有选手分为胜者和败者两组,最终产生的冠军不会出现在败者组当中。
因此:失败过的选手+1=总选手*/
int main()
{
    while(cin>>n&&n){
        set<string> tol,failed;
        tol.clear();
        failed.clear();
        for(int i=0;i<n;i++){
            string a,b;
            cin>>a>>b;
            tol.insert(a),tol.insert(b);
            failed.insert(b);
        }
        if(failed.size()+1==tol.size()) cout<<"Yes"<<endl;
        else cout<<"No"<<endl;
    }
    return 0;
}

原文链接:https://www.cnblogs.com/yulianyi/p/17278546.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:F – 产生冠军(不使用拓扑排序) - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • 稀疏数组

    引入 当在网页上下棋类游戏时,玩到中途想要离开,但是我们需要保存进度,方便下次继续 我们应该怎么实现 ? 以围棋举例 使用二维数组将棋盘记下 ,如 0 为 没有棋子 ,1 为 黑子 , 2为白子 但是没有棋子的地方都为 0 ,整个二维数组充斥着大量的无效数据 0 我们需要想一个办法来 优化存储的方式 基本介绍 当一个数组中大部分元素是同一个值时,我们可以使用…

    算法与数据结构 2023年4月25日
    00
  • C++深入分析讲解链表

    C++深入分析讲解链表 链表概述 链表是数据结构中最基本和重要的一种,它的实现可以分为链表的节点和链表的指针。每个节点都记录着链表中的一个元素,并带有一个指向下一个节点的指针,这样就可以通过遍历指针,达到遍历链表的目的。 链表数据结构 在C++中,链表可以通过结构体或者类来实现,比如以下这个结构体实现的单向链表: struct Node { int data…

    数据结构 2023年5月17日
    00
  • python人工智能算法之人工神经网络

    Python人工智能算法之人工神经网络 人工神经网络是一种常用的机器学习算法,它可以用于分类、回归和聚类等问题。本文将细介绍Python中人工神经网络的流,包括数据预处理、模型构建和模型训练等步骤。 1.预处理 在使用人工神经网络算法之前,需要对数据进行预处理。具体来说,需要进行以下步骤: 1. 数据清洗 数据清洗是指对数据去重、缺失值处理、异常值处理等操作…

    python 2023年5月14日
    00
  • python实现基于朴素贝叶斯的垃圾分类算法

    Python实现基于朴素贝叶斯的垃圾分类算法 1. 简介 朴素贝叶斯是一种常用的机器学习算法,它可以用于分类和文本分类问题。本文将介绍如何使用Python现基于朴素贝叶斯的垃圾分类算法。 2. 数据集 我们将使用一个包含5572个短信的数据集来演示如何使用朴素贝叶斯算法进行垃圾分类。每个短信有一个类别标签:spam或ham。以下是数据集的示例: Label …

    python 2023年5月14日
    00
  • python实现人工蜂群算法

    下面是详细讲解“python实现人工蜂群算法”的完整攻略,包含两个示例说明。 人工蜂群算法简介 人工蜂群算法(Artificial Bee Colony,ABC)是一种基于蜜蜂觅食行为的优化算法。在ABC算法中,蜜蜂分为三种角色:雇佣蜜蜂、侦查蜜蜂和观察蜜蜂。雇佣蜜蜂和侦查蜜蜂负责搜索解空间,观察蜜蜂负责评估解的质量。ABC算法的优点是易于实现,收敛速度快,…

    python 2023年5月14日
    00
  • 详解桶排序算法原理与使用方法

    桶排序(Bucket Sort)是一种排序算法,它在待排序元素分布比较均匀的情况下能够比较快速地进行排序。桶排序的基本思路是将待排序的元素分别放到不同的桶中,再对所有的桶进行排序,最后依次将桶中的元素取出。 桶排序的主要作用是对大量数据进行排序,可以用于处理大数据量的文件排序和高考成绩排名等应用场景。 桶排序的具体实现方法如下: 确定桶的个数:对于待排序元素…

    算法 2023年3月27日
    00
  • Python素数检测的方法

    Python素数检测是数学中的一个重要问题,Python可以很方便地实现这个操作。本文将介绍Python实现素数检测的完整攻略,包括两个示例说明。 1. 基本思路 素数是只能被1和自身整除的正整数,因此,我们可以从2开始,一直到这个数的平方根,检查这个数是否能被这些数整除。具体实现如下: def is_prime(n): if n < 2: retur…

    python 2023年5月14日
    00
  • C语言数据结构之简易计算器

    C语言数据结构之简易计算器攻略 简介 这是一个基于C语言的简易计算器,可以实现加、减、乘、除四个基本运算。 实现步骤 首先,需要声明四个变量,分别表示运算符、被加数、被减数、被乘数和被除数。 char op; double n1, n2, result; 然后,需要通过scanf()函数获取用户输入的运算符和数字。 printf(“请输入运算符和数字:\n”…

    数据结构 2023年5月17日
    00
合作推广
合作推广
分享本页
返回顶部