P1006 [NOIP2008 提高组] 传纸条

洛谷的题

网址:P1006 [NOIP2008 提高组] 传纸条 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

还是动态规划,这题和我上一篇博客写的题差不多

区别在于,这个地图不再是方阵,路线不能交叉,而且地图的大小可能大得多

但是思路都是相似的(或许你可以想想为什么路线不能交叉的影响不大)

解题思路就不赘述了

代码如下:

#include<stdio.h>
int getmax(int a, int b, int c, int d);
int m, n, map[51][51] = {0}, dp[51][51][51][51] = {0};

int main(void)
{
    //输入
    scanf("%d%d", &m, &n);
    for(int i = 1 ; i <= m; i++)
        for(int j = 1; j <= n; j++)
            scanf("%d", &map[i][j]);
    //开始动态规划
    for(int i = 1; i <= m + n - 2; i++)//i代表走了几步
    {
        for(int x1 = 1; x1 <= i + 1 && x1 <= m; x1++)
        {
            int y1 = 2 + i - x1;
            if(y1 > n) continue;
            for(int x2 = 1; x2 <= i + 1 && x2 <= m; x2++)
            {
                if(x1 == x2)  continue;
                int y2 = 2 + i - x2;
                if(y2 > n)  continue;
                dp[x1][y1][x2][y2] = getmax(dp[x1 - 1][y1][x2 - 1][y2], dp[x1 - 1][y1][x2][y2 - 1], dp[x1][y1 - 1][x2 - 1][y2], dp[x1][y1 - 1][x2][y2 - 1]);
                dp[x1][y1][x2][y2] += map[x1][y1] + map[x2][y2];
            }
        }
    }
    //输出结果
    printf("%d", getmax(dp[m - 1][n][m][n - 1], dp[m][n - 1][m - 1][n], 0, 0));

    return 0;
}
int getmax(int a, int b, int c, int d)
{
    a = (a > b) ? a : b;
    a = (a > c) ? a : c;
    return (a > d) ? a : d;
}

但是在运行的时候,我遇到了前所未有的问题:

在主函数开始的时候(还没执行任何语句)就出现了segmentation fault!

为什么呢?

记得在算法书上看过,对于比较大的数组,最好把它设置为全局变量

因为动态变量是储存在栈堆段上的,栈堆段的内存有限,太大会内存溢出

小改了一下就解决了

  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值