这个是题目翻译过后。
这个题目就一个知识点,就是可图形判断,给你一个各个顶点度的序列,让你判断它能不能画出图。
我还没有学过离散数学,所以最开始并不知道这个定理。其实这个定理非常好理解,讲顶点序列排降序后我们默认第一个顶点的相邻几个顶点就是其后面的几个顶点,也就是说如果把其后面几个顶点的度都减去1,并且把自己设置为0。然后经过排序后再处理下一个顶点。
样例的处理过程如下:
4 4 3 3 2 2 排序后 4 4 3 3 2 2
0 3 2 2 1 2 排序后 0 3 2 2 2 1
0 0 1 1 1 1 排序后 0 0 1 1 1 1
0 0 0 0 1 1 排序后 0 0 0 1 1 0
0 0 0 0 0 0 排序后 0 0 0 0 0 0
只要处理后的序列全部都为0那就说明该序列可图
#include<bits/stdc++.h>
using namespace std;
int a[1005];
int cmp(int a,int b)
{
return a>b;
}
int main()
{
int t;
while(cin>>t)
{
while(t--)
{
int n;
cin>>n;
for(int i=0;i<n;i++)
cin>>a[i];
sort(a,a+n,cmp);
int flag=1;
for(int i=0;i<n;i++)
{
sort(a+i,a+n,cmp);
// for(int k=0;k<n;k++)
// cout<<a[k]<<" ";
// cout<<endl;
for(int j=i+1;j<=i+a[i];j++)
{
a[j]-=1;
if(a[j]<0)
{
cout<<"no"<<endl;
flag=0;
break;
}
}
if(flag==0)
break;
a[i]=0;
}
if(flag)
cout<<"yes"<<endl;
}
}
return 0;
}