USACO数字三角形 - 执行错误

时间:2012-03-15 11:28:04

标签: algorithm optimization dynamic-programming

问题如下

考虑下面显示的数字三角形。编写一个程序,计算可以在从顶部开始到底部某处的路径上传递的最大数字总和。每个步骤都可以向左斜下方或向右斜下方。

      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个测试用例失败。

感谢您的帮助!

1 个答案:

答案 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。我很确定这是导致错误的原因。