时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
有nn名选手会进行mm次比赛,每次比赛不会出现平局的情况,只会有一个胜者。在每次比赛完成之后,我们视胜者选手的实力比败者选手的实力强,如果出现选手AA打败选手BB,选手BB打败选手CC,选手CC打败选手AA,则视为他们的实力全部相同。
若该赛季最终冠军是属于实力最强者,请问依照现在已有的比赛结果,最多有多少个选手可能获得冠军(如果已知两个人的实力一样强,那么他们两个人都不能获得冠军)。
输入描述:
第一行输入两个正整数nn,mm,其中:n\leq 10^{5}n≤10
5
,m\leq 10^{5}m≤10
5
。
接下来mm行,每行两个正整数aa与bb,代表选手aa战胜了选手bb,满足:a\leq na≤n,b\leq nb≤n。
输出描述:
输出最多有多少名选手最终可能获得冠军。
示例1
输入
复制
3 2
1 2
1 3
输出
复制
1
#include<iostream>
#include<set>
using namespace std;
int main(){
set<int> s;
int n,m;
cin>>n>>m;
for(int i=1;i<=m;i++){
int a,b;
cin>>a>>b;
s.insert(b);
}
int count=n-s.size();
cout<<count<<endl;
return 0;
}