分析一下最后一步从哪些情况来,然后根据集合属性进行max操作
#include<bits/stdc++.h>
using namespace std;
const int N=1010;
int t,n,m;
int a[N][N];
int dp[N][N];
int main()
{
cin>>t;
while(t--)
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>a[i][j];
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
dp[i][j]=max(dp[i-1][j]+a[i][j],dp[i][j-1]+a[i][j]);
}
}
cout<<dp[n][m]<<endl;
}
return 0;
}