本文介绍: 在主函数开始的时候(还没执行任何语句)就出现了segmentation fault!区别在于,这个地图不再是方阵,路线不能交叉,而且地图的大小可能大得多。但是思路都是相似的(或许你可以想想为什么路线不能交叉的影响不大)因为动态变量是储存在栈堆段上的,栈堆段的内存有限,太大会内存溢出。记得在算法书上看过,对于比较大的数组,最好把它设置为全局变量。还是动态规划,这题和我上一篇博客写的题差不多。
洛谷的题
网址: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!
为什么呢?
记得在算法书上看过,对于比较大的数组,最好把它设置为全局变量
因为动态变量是储存在栈堆段上的,栈堆段的内存有限,太大会内存溢出
小改了一下就解决了
原文地址:https://blog.csdn.net/Fool256353/article/details/134815880
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_49122.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。