zoukankan      html  css  js  c++  java
  • 【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;
    }
  • 相关阅读:
    逆元
    C++快读
    最长单调上升子序列(LIS) O(nlogn)求法
    【简●解】巴厘岛的雕塑
    【简●解】学校食堂
    【简●解】[HNOI2005]星际贸易
    差分约束系统小结
    【简•解】花园
    最小生成树小结
    概率及期望DP小结
  • 原文地址:https://www.cnblogs.com/gwj1314/p/9444844.html
Copyright © 2011-2022 走看看