bzoj 3997 组合数学

最小链覆盖等于最大独立集。
两个点不相互可达则一个数在另一个数的左下角,dp即可。

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>

#define ll long long
#define inf 1e9
#define eps 1e-10
#define md
#define N 1010
using namespace std;
ll f[N][N],a[N][N];
int main()
{
int tt;
scanf("%d",&tt);
while (tt--)
{
int n,m;
scanf("%d%d",&n,&m);
for (int i=n;i;i--)
for (int j=1;j<=m;j++)
scanf("%d",&a[i][j]);
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
f[i][j]=max(max(f[i-1][j],f[i][j-1]),f[i-1][j-1]+a[i][j]);
printf("%d\n",f[n][m]);
}
return 0;
}

你可能感兴趣的:(bzoj 3997 组合数学)