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

(DP)To The Max --HDU -- 1081

时间:2015-08-21 15:05:23      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:

链接:

http://acm.hdu.edu.cn/showproblem.php?pid=1081

 

代码:

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define max2(a,b) (a>b?a:b)

#define N 110
#define INF 0xfffffff

int a[N][N], b[N][N][N];

int main()
{
    int n;
    while(scanf("%d", &n)!=EOF)
    {
        int i, j, k, x, max1;

        memset(a, 0, sizeof(a));
        memset(b, 0, sizeof(b));

        for(i=1; i<=n; i++)
        for(j=1; j<=n; j++)
            scanf("%d", &a[i][j]);

        max1=-INF;
        for(i=1; i<=n; i++)
        for(j=1; j<=n; j++)
        for(x=0, k=j; k>0; k--)
        {
            x += a[i][k];

            b[i][j][k] = max2(b[i][j][k], b[i-1][j][k]) + x;

            if(b[i][j][k]>max1)
                max1 = b[i][j][k];
        }

        printf("%d\n", max1);
    }
    return 0;
}

 

(DP)To The Max --HDU -- 1081

标签:

原文地址:http://www.cnblogs.com/YY56/p/4747548.html

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