题目链接
题目大意
现在有m对数字(ai,bi),问你是否可以找出两个数字x和y,使得每一对数中都至少有一个数等于x或者y
解题思路
根据题意我们可以知道:x和y至少是a1和b1中的其中一个,所以我们假设x是a1或者x是b1,然后找出剩下的所有不包含x的对数中,是否存在一个y使得剩下的所有对数中都包含y。我是用map模拟的。
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<map>
using namespace std;
struct node
{
int a,b;
};
node e[300005];
map<int,int>ma;
int main()
{
int n,m;
while(~scanf("%d %d",&n,&m))
{
int flag=0;
for(int i=1; i<=m; i++)
scanf("%d %d",&e[i].a,&e[i].b);
int x=e[1].a,ans=0;//假设x是a1,ans是不包含a1的对数有多少个
ma.clear();
for(int i=2; i<=m; i++)
{
if(e[i].a!=x&&e[i].b!=x)
{
ans++;
ma[e[i].a]++;
ma[e[i].b]++;
}
}
for(int i=2; i<=m; i++)
{
if(e[i].a!=x&&e[i].b!=x)//是否存在一个数出现的次数正好等于ans
{
if(ma[e[i].a]==ans)
flag=1;
if(ma[e[i].b]==ans)
flag=1;
}
}
if(ans==0)//所有的对数都包含a1
flag=1;
x=e[1].b;ans=0;//假设x等于b1,ans是不包含b1的对数的个数
ma.clear();
for(int i=2; i<=m; i++)
{
if(e[i].a!=x&&e[i].b!=x)
{
ans++;
ma[e[i].a]++;
ma[e[i].b]++;
}
}
for(int i=2; i<=m; i++)
{
if(e[i].a!=x&&e[i].b!=x)
{
if(ma[e[i].a]==ans)
flag=1;
if(ma[e[i].b]==ans)
flag=1;
}
}
if(ans==0)所有的对数都包含b1
flag=1;
if(m==1||flag)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}