zoj1909 Square dfs+优化(参考别人的)

16 篇文章 0 订阅

本以为自己对dfs了解的可以了,可是这道题,我还是参看了别人的代码,自己设计的dfs不论怎样跳出,一直TLE。。。伤不起啊。。。

里面是各种return。。。。。。

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
int vis[20],len[20],n,aver;
int dfs(int i,int j,int amount)
{
  if(amount<0||j<0) return 0;
  if(amount==0)
  {
    if(i==2) return 1;
    return dfs(i+1,n-1,aver);
  }
  if(!vis[j])
  {
    vis[j]=1;
    if(dfs(i,j-1,amount-len[j])) return 1;
    vis[j]=0;
    while(j&&len[j]==len[j-1])
      j--;
  }
  return dfs(i,j-1,amount);
}
int main()
{
  int k,i,flag;
  scanf("%d",&k);
  while(k--)
  {
    scanf("%d",&n);
    aver=0;
    for(i=0;i<n;i++)
    {
      scanf("%d",&len[i]);
      aver+=len[i];
    }
    if(aver%4)
    {
      printf("no\n");
      continue;
    }
    else
    {
      aver/=4;
      sort(len, len+n);
      if(len[n-1]>aver)
      {
        printf("no\n");
        continue;
      }
      memset(vis,0,sizeof(vis));
      flag=dfs(0,n-1,aver);
      if(flag) printf("yes\n");
      else  printf("no\n");
    }
  }
  return 0;
}      


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值