给定一组不同长度的木棍,是否有可能将它们端对端地连接起来形成 个正方形?
第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
- 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";
- }
- }