码迷,mamicode.com
首页 > 其他好文 > 详细

题解 P7074 【方格取数】

时间:2021-05-03 12:57:39      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:int   i+1   整数   href   取数   --   ret   clu   tle   

题目
由于有三个方向,所以在普通二维dp上再加一个方向维度,用三维数组进行dp。

  • \(f[i][j][\)\(]\)\(f[i][j][0]\)) 表示从当前格子的左边走到当前格子能取到的最大整数之和。
  • \(f[i][j][\)\(]\)\(f[i][j][1]\)) 表示当前格子的上边边走到当前格子能取到的最大整数之和。
  • \(f[i][j][\)\(]\)\(f[i][j][2]\)) 表示当前格子的下边走到当前格子能取到的最大整数之和。

思路

先进行第 \(1\) 列的填值。
因为其处在整个地图的最左侧,所以只有 ↓ 方向是可以取到格子里的数的(如果向上走,最后必将无路可走)。
f[i][1][1] = f[i-1][1][1] + a[i][1]
然后再进行第 \(2\) ~ \(m\) 列的填值。
先填 → 方向及 ↓ 方向的值,再从下往上填 ↑ 方向的值。

f[i][j][0] = max(f[i][j-1][0],f[i][j-1][1],f[i][j-1][2]) + a[i][j]
f[i][j][1] = max(f[i-1][j][0],f[i-1][j][1]) + a[i][j])
f[i][j][2] = max(f[i+1][j][0],f[i+1][j][2]) + a[i][j])

最后输出:

max(f[n][m][0],f[n][m][1],f[n][m][2])

\(Code\)

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf -1e17
ll f[1005][1005][3];
ll a[1005][1005];
int n,m;
ll maxx(ll a,ll b)
{
    return a>b ?a :b;
}
int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            cin>>a[i][j];
            f[i][j][0] = inf;
            f[i][j][1] = inf;
            f[i][j][2] = inf;

        }
    }
    f[1][1][0]=a[1][1];
    f[1][1][1]=a[1][1];
    f[1][1][2]=a[1][1];
    for(int i=2;i<=n;i++)
    {
        f[i][1][1] = f[i-1][1][1] + a[i][1];
    }
    for(int j=2;j<=m;j++)
    {
        for(int i=1;i<=n;i++)
        {
            f[i][j][0]=maxx(f[i][j-1][1],maxx(f[i][j-1][0],f[i][j-1][2]))+a[i][j];
            if(i>=2) f[i][j][1]=maxx(f[i-1][j][0],f[i-1][j][1])+a[i][j];  //↓方向
        }
        for(int i=n-1;i>=1;i--)  //↑方向
        {
            f[i][j][2]=maxx(f[i+1][j][0],f[i+1][j][2])+a[i][j];
        }
    }
    cout<<maxx(f[n][m][0],maxx(f[n][m][1],f[n][m][2]));
    return 0;
}

题解 P7074 【方格取数】

标签:int   i+1   整数   href   取数   --   ret   clu   tle   

原文地址:https://www.cnblogs.com/uyisnil/p/14724297.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!