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

POJ3176

时间:2014-05-16 03:17:40      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:c   int   get   a   set   os   

#include <STDIO.H>
#include <MALLOC.H>
#define max(a, b) (((a) > (b)) ? (a) : (b))
void GetMaxCost(int **data, int **result, int n)
{
int i, j;
for(j = 1; j <= n; j++)
{
result[n][j] = data[n][j];
}

for(i = n-1; i >= 1; i--)
{
for(j = 1; j <= i; j++)
{
result[i][j] = max(result[i + 1][j] + data[i][j], result[i + 1][j + 1] + data[i][j]);
}
}
}
void main()
{
int **data = NULL;
int **result = NULL;
int n, i, j, max;
scanf("%d", &n);
data = (int **)malloc(sizeof(int *) * (n + 1));
result = (int **)malloc(sizeof(int *) * (n + 1));
for(i = 1; i <= n; i++)
{
data[i] = malloc(sizeof(int) * (i + 1));
result[i] = malloc(sizeof(int) * (i + 1));
memset(data[i], 0, sizeof(int) * (i + 1));
memset(result[i], 0, sizeof(int) * (i + 1));
}

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

GetMaxCost(data, result, n);

max = 0;
for (i = 1; i <= n; i++)
{
for(j = 1; j <= i; j++)
{
if(result[i][j] > max)
max = result[i][j];
}
}

printf("%d", max);


}

POJ3176,布布扣,bubuko.com

POJ3176

标签:c   int   get   a   set   os   

原文地址:http://www.cnblogs.com/jsy306/p/3729626.html

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