http://poj.org/problem?id=1011經典搜尋dfs

來源:互聯網
上載者:User

自己第一次在linux下用vim 編寫的代碼,並且A題的,很高興;

就是poj上面的一個搜尋題;題目很是經典,搜尋剪枝最佳化;

#include<cstdio>#include<string.h>#include<stdlib.h>#include<algorithm>using namespace std;int num[65];bool vis[65];int Max;int sum;bool ok;int n;int len;void dfs(int left,int con,int k,int cnt){     if(cnt==con){           if(left==len) ok=true;return;     }int pre=-1;     for(int i=k;!ok&&i<n;++i){           if(!vis[i]&&pre!=num[i]&&left>=num[i]){  pre=num[i];       vis[i]=true;  if(left==num[i])                   dfs(len,con,0,cnt+1);else                   dfs(left-num[i],con,i+1,cnt); vis[i]=false;                   if(k==0)return;}     }}bool cmp(int x,int y){return x>y;}int main(){ while(~scanf("%d",&n)&&n){    Max=-999;      ok=false;    sum=0;   for(int i=0;i<n;i++){          scanf("%d",&num[i]);        sum+=num[i];            vis[i]=false; //if(num[i]>Max)   //       Max=num[i];     }sort(num,num+n,cmp);    for(int i=num[0];i<sum;i++){if(sum%i==0){memset(vis,false,sizeof(vis));                      int con=sum/i;      len=i;     dfs(i,con,0,0);if(ok){printf("%d\n",len);//printf("%d\n",len);break;  }}                    }   if(!ok)printf("%d\n",sum);  }  return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.