题目描述
给定一组不同长度的木棍,是否有可能将它们端对端地连接起来形成 个正方形?
输入格式
第1行输入包含N,即测试数据的数量。 每组测试数据第一个数为 ,即木棒的根数。之后有 个整数, 每个都给出了一根棍子的长度 。
输出格式
对于每种情况,如果可以形成正方形,则输出 yes
或 no
,每个结果占 行。
样例
样例输入
复制3
4 1 1 1 1
5 10 20 30 40 50
8 1 7 2 6 4 4 3 5
样例输出
复制yes
no
yes
_____________________________________________________________________________
写作不易,点个赞呗!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
_____________________________________________________________________________
#include <bits/stdc++.h>
using namespace std;
int a[100],v[100],n,len,cnt,z;
bool dfs(int s,int c,int l){if(s>cnt)return true;if(c==len)return dfs(s+1,0,1);int g=0;for(int i=l;i<=n;i++){if(!v[i]&&c+a[i]<=len&&g!=a[i]){v[i]=1;if(dfs(s,c+a[i],i+1)) return true;g=a[i];v[i]=0;if(c==0||c+a[i]==len) return false;}}return false;
}
int main(){cin>>z;for(int c=1;c<=z;c++){cin>>n;int sum=0,ans=0;for(int i=1;i<=n;i++){scanf("%d",&a[i]);sum+=a[i];ans=max(ans,a[i]);}sort(a+1,a+1+n);reverse(a+1,a+n+1);for(len=ans;len<=sum;len++){if(sum%len)continue;cnt=sum/len;memset(v,0,sizeof(v));if(dfs(1,0,1)) break;}if(len*4==sum)cout<<"yes\n";else cout<<"no\n";}
}