问题如下
考虑下面显示的数字三角形。编写一个程序,计算可以在从顶部开始到底部某处的路径上传递的最大数字总和。每个步骤都可以向左斜下方或向右斜下方。
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5 在上面的示例中,从7到3到8到7到5的路由产生最高总和:30。
我遇到以下错误
Your program had this runtime error: Bad syscall #32000175 (RT_SIGPROCMASK) [email kolstad if you think this is wrong]. The program ran for 0.259 CPU seconds before the error. It used 16328 KB of memory.
代码如下。
int arr[1500][1500];
map < int,map < int,int> >dp;
int main()
{
// ofstream fout ("numtri.out");
// ifstream fin ("numtri.in");
int n;
// fin>>n;
freopen ("numtri.in", "r", stdin);
freopen ("numtri.out", "w", stdout);
scanf ("%d", &n);
int ct = 1;
int gaga = -100;
for (int i=0; i<n; i++)
{
for (int j=0; j<ct; j++)
{
scanf ("%d", &arr[i][j]);
if(i>0)
dp[i][j] = maxi (dp[i-1][j-1] + arr[i][j], dp[i-1][j] + arr[i][j]);
else
dp[0][0]=arr[0][0];
if (i == n-1)
{
if (dp[i][j] > gaga)
gaga=dp[i][j];
}
}
ct++;
}
printf ("%d\n", gaga);
return 0;
}
它在我的笔记本电脑上工作正常。在网站上,它适用于8个测试用例,并且第9个测试用例失败。
感谢您的帮助!
答案 0 :(得分:4)
if(i>0)
dp[i][j]=maxi(dp[i-1][j-1]+arr[i][j],dp[i-1][j]+arr[i][j]);
您检查是否i > 0
,这将确保您永远不会访问负面索引。但是,对于j
,您永远不会这样做,因此您将在内部(dp[i-1][-1]
)循环的第一次运行时访问j
。我很确定这是导致错误的原因。