NYOJ-171 填表法 普通dp

Posted 若有恒,何必三更起五更眠;最无益,莫过一日曝十日寒。

tags:

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

题目链接:

http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=171

分析:

kk每次只能向右边和下边走,所以取他的上面和左边的最大值加上自己

dp[i][j]=f_max(dp[i-1][j],dp[i][j-1])+a[i][j];

代码如下:

#include<bits/stdc++.h>
#define pai 3.1415926535898
using namespace std;
int f_max(int a,int b)
{
    if(a>b)
    {
        return a;
    }else
    {
        return b;
    }
}
int main()
{
    int n,m;
    scanf("%d %d",&n,&m);
    int a[n+1][m+1];
    memset(a,0,sizeof(a));
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
    int dp[n+1][m+1];
    memset(dp,0,sizeof(dp));
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            dp[i][j]=f_max(dp[i-1][j],dp[i][j-1])+a[i][j];
        }
    }
    printf("%d\n",dp[n][m]);
    return 0;
}

 

以上是关于NYOJ-171 填表法 普通dp的主要内容,如果未能解决你的问题,请参考以下文章

易语言网页填表

算法第三章

Luogu P2051 [AHOI2009]中国象棋 //DP

最大m子段和问题(动态规划(又来填表了....))

易语言知道元素ID怎么点击

换根dp