3 75 15 21 75 15 28 34 70 5
188
#include <iostream>
#include <sstream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#include <queue>
#include <algorithm>
#include <map>
#include <cmath>
#include <iomanip>
#define INF 99999999
typedef long long LL;
using namespace std;
const int MAX=17711+10;
int n,nowsize,lastsize;
int now[MAX],last[MAX];
int dp[MAX],temp[MAX],ans[MAX];
int w[22][22];
void dfs(int id,int k,int p,int sum){
if(k>=n){now[++nowsize]=p;ans[nowsize]=sum;return;}
dfs(id,k+2,p|(1<<k),sum+w[id][k]);
dfs(id,k+1,p,sum);
}
void DP(){
for(int k=1;k<=n;++k){
nowsize=0;
dfs(k,0,0,0);
for(int i=1;i<=nowsize;++i)dp[i]=0;
for(int i=1;i<=nowsize;++i){
for(int j=1;j<=lastsize;++j){
if(now[i] & last[j])continue;
dp[i]=max(dp[i],temp[j]+ans[i]);
}
}
for(int i=1;i<=nowsize;++i)temp[i]=dp[i];
for(int i=1;i<=nowsize;++i)last[i]=now[i];
lastsize=nowsize;
}
}
int main(){
while(~scanf("%d",&n)){
for(int i=1;i<=n;++i){
for(int j=0;j<n;++j)scanf("%d",&w[i][j]);
}
temp[1]=last[1]=0;
lastsize=1;
DP();
int sum=0;
for(int i=1;i<=lastsize;++i)sum=max(sum,temp[i]);
printf("%d\n",sum);
}
return 0;
}
原文:http://blog.csdn.net/xingyeyongheng/article/details/21551769