hdu 2686

这个题目在面试的时候被问到了,首先问我的是一个人版本的,然后增加到两个人版本的。

题目的含义是:一个n*n的棋盘,每个棋盘上有金矿,该金矿拿走后就没有了,问一个人从(0,0)->(n,n)然后再从(n,n)->(0,0)(这次的路径不能和上次的重叠),使得两次的和最大。


这道题目我一点思路也没有,网上看了一下,据说是双线程dp,状态转移方程为:dp(k,x1,y1,x2,y2)=max(dp(k-1,x1-1,y1,x2-1,y2), dp(k-1,x1-1,y1,x2,y2-1), dp(k-1,x1,y1-1,x2-1,y2), dp(k-1,x1,y1-1,x2,y2-1))+mat[x1][y1]+mat[x2][y2]; k表示从起点(1,1)到该点的步数,另外根据x1+y1=k可以对该dp方程进行降维,降维后的dp方程为:

dp(k,x1,x2)=max(dp(k-1,x1-1,x2-1), dp(k-1,x1-1,x2), dp(k-1,x1,x2-1), dp(x1,x2))+mat[x1][k-x1]+mat[x2][k-x2];


代码如下:


你可能感兴趣的:(hdu 2686)