双线程dp

Posted 让自己不再小小的

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了双线程dp相关的知识,希望对你有一定的参考价值。

zznu 1625

详解链接:http://blog.csdn.net/su20145104009/article/details/51277041

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<cctype>
#include<algorithm>
#include <vector>
#include <queue>

using namespace std;
#define INF 0x3f3f3f3f
#define N 55

int maps[N][N];
int dp[N][N][N][N];

int main()
{
    int T, m, n;
    scanf("%d", &T);

    while(T--)
    {
        scanf("%d%d", &m, &n);
        for(int i=1; i<=m; i++)
        for(int j=1; j<=n; j++)
            scanf("%d", &maps[i][j]);

        memset(dp, 0, sizeof(dp));

        for(int i=1; i<=m; i++)
        for(int j=1; j<=n; j++)
        for(int k=i+1; k<=m; k++)
        {
            int l=i+j-k;
            if(l<0 || l>n) break;
            dp[i][j][k][l]=max(max(dp[i-1][j][k][l-1], dp[i-1][j][k-1][l]),
                               max(dp[i][j-1][k-1][l], dp[i][j-1][k][l-1]))+maps[i][j]+maps[k][l];
        }
        printf("%d\n", max(max(dp[m-1][n][m][n-1], dp[m-1][n][m-1][n]),
                               max(dp[m][n-1][m-1][n], dp[m][n-1][m-1][n]))+maps[m][n]);
    }
    return 0;
}

 

以上是关于双线程dp的主要内容,如果未能解决你的问题,请参考以下文章

NOIP 2008 传纸条题解[双线程DP]

使用 ActionBar 旋转 Android 的双片段

newCacheThreadPool()newFixedThreadPool()newScheduledThreadPool()newSingleThreadExecutor()自定义线程池(代码片段

添加两个窗格的平板电脑布局会导致在移动设备中找不到视图(小于w600dp)

1024. 视频拼接 dp

3583. 整数分组 (双指针+dp)