• 【NOIP2008】【Vijos1493】传纸条


    problem

    在一个矩阵内找出两条从(1,1)到(m,n)的路径(一条从1,1 到 m,n 一条 从m, n到1,1),并且路径之上的权值之和最大。

    solution

    状态:f[i][j][k][l],当一张纸条传到i,j 另一张传到k,l时路径上权值的最大值;

    codes

    //考虑题设,找到两条不重复的路径,所以从上到下直接DP,状态四维(上往下,下往上分别DP,没办法考虑路径重叠)
    //f[i][j][k][l]表示分别到(i,j),(k,l)时候的最大好心值
    #include<iostream>
    #include<algorithm>
    using namespace std;
    int n, m, a[110][110], f[110][110][110][110];
    int main(){
        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++)
                for(int k = 1; k <= n; k++)
                    for(int l = 1; l <= m; l++)
                        if(!(i==k&&j==l) || (i==n&&j==m&&k==n&&l==m))
                            f[i][j][k][l] = max(max(f[i-1][j][k-1][l], f[i][j-1][k-1][l]), max(f[i-1][j][k][l-1],f[i][j-1][k][l-1]))+a[i][j]+a[k][l];
        cout<<f[n][m][n][m]<<"
    ";
        return 0;
    }
  • 相关阅读:
    自定义线性表
    网站关键词抓住热点话题获取长尾关键词 给网站增添流量(图)
    Hibernate常见注解说明
    面试问题java基础
    Spring常见的注解说明
    poj3268
    poj3273
    poj3250
    poj3277
    poj3253
  • 原文地址:https://www.cnblogs.com/gwj1314/p/9444844.html
Copyright © 2020-2023  润新知