蛤玮的财宝

1875: 蛤玮的财宝

Time Limit: 1 Sec   Memory Limit: 128 MB
Submit: 320   Solved: 51

Submit Status Web Board

Description

蛤玮和他的妹子出海游玩,不小心遭遇了海难,他们醒来之后发现自己到了一座金银岛.岛主非常好心的告诉他们在岛的另一边有船可以送他们回家.
这座岛可以看成n*m的矩阵,蛤玮他们在位置(1,1),而船在位置(n,m).蛤玮发现金银岛遍地都是金子,每个格子里有价值a[i,j]的金子,他和妹子打算在回去的路上带一些走.如果他们路过了位置(i,j),就可以假装系鞋带捡走地上的金子.为了不引起怀疑,他们在走的时候只能往接近码头的方向走,即如果蛤玮现在在(i,j),他只能移动到(i+1,j)或者(i,j+1).为了能拿走更多的金子,蛤玮和妹子决定装作互相不认识,这样他们就可以分开走,从而拿到更多的金子.
蛤玮和他妹子想知道他们最多能拿走多少金子.
注意如果蛤玮和他妹子经过了相同的地方,只能得到一次金子,因为地上的捡完就没有了.

Input

T(1<=T<=10),表示数据组数.
每组数据第一行n,m(1<=n,m<=100),接下来n行,每行m个数,第i行第j列的值a[i,j](1<=a[i,j]<=1000)表示位置(i,j)的金子的价值.

Output

每组数据输出一行,蛤玮和他妹子能拿到的金子总价的最大值.

Sample Input

12 22 11 2

Sample Output

6

AC代码:

由于只能往下往右走,所以两条路径的长度是一样的,用dp[k][i][j]表示两个人都走了k步,第一个人在第i行,第二个人在第j行所能得到的最大值,两个人分别往下或往右走一步,有四种转移,如果走到了相同点则权值只加一个
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int dp[210][110][110],map[110][110];
int main()
{
	int K,N,M;
	int i,j,k;
	int t,l;
	while(cin>>K)
	while(K--){
		cin>>N>>M;
		for(i=1;i<=N;i++)
		for(j=1;j<=M;j++)
		cin>>map[i][j];
		memset(dp,0,sizeof(dp));
		dp[2][1][1]=map[1][1];
		for(k=3;k<N+M;k++){
			for(i=1;i<=N;i++){
				for(j=1;j<=N;j++){
					t=k-i;
					l=k-j;
					if(t<1||l<1)break;
					if(t>M||l>M)continue;
					dp[k][i][j]=max(max(dp[k-1][i-1][j],dp[k-1][i-1][j-1]),max(dp[k-1][i][j-1],dp[k-1][i][j]))+map[i][t]+map[j][l];
					if(i==j&&t==l)dp[k][i][j]-=map[i][t];
				}
			}
		}
		dp[N+M][N][N]=max(max(dp[N+M-1][N-1][N],dp[N+M-1][N-1][N-1]),max(dp[N+M-1][N][N-1],dp[N+M-1][N][N]));
		cout<<dp[N+M][N][N]+map[N][M]<<endl;
	}
	return 0;
} 



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值