看完题,第一个反应是k<=5,这个肯定要利用。
然后求曼哈顿距离的最大,就要把绝对值拆成+ -的形式
这样状态就可以表示了,每个副武器属性的+一定对应主武器的-,所以可以先把每个状态主武器的最大值求出来,然后用副武器去匹配
#include<iostream>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
int t;ll save[8],dp[1000];int ji;
int main()
{
scanf("%d",&t);
while(t--)
{
int n,m,k;
scanf("%d%d%d",&n,&m,&k);
for(int i=0;i<=(1<<k);i++)
dp[i]=-1e9*10000;
for(int i=1;i<=n;i++)
{
ll te;
scanf("%lld",&te);
for(int j=1;j<=k;j++)
scanf("%lld",&save[j]);
for(int j=0;j<=(1<<k)-1;j++)
{
ll sum=te;
ji=j;
for(int l=1;l<=k;l++)
{
if(ji%2==1)
sum+=save[l];
else
sum-=save[l];
ji=ji/2;
}
dp[j]=max(dp[j],sum);
}
}
ll ans=-1e9*10000;
for(int i=1;i<=m;i++)
{
ll te;
scanf("%lld",&te);
for(int j=1;j<=k;j++)
scanf("%lld",&save[j]);
for(int j=0;j<=(1<<k)-1;j++)
{
ll sum=te;
ji=j;
for(int l=1;l<=k;l++)
{
if(ji%2==1)
sum-=save[l];
else
sum+=save[l];
ji=ji/2;
}
ans=max(ans,dp[j]+sum);
}
}
printf("%lld\n",ans);
}
return 0;
}