0

所以我有这个函数,它使用递归来找到最长的数字序列。但每次我运行它时,我都会收到以下错误消息:

增加 Seq.exe 中 0x002871D9 处的未处理异常:0xC0000005:访问冲突写入位置 0x01060EC0。

int seqeter(int grid, int startPos,  int seq)
{
    Sequence maxseq;
    maxseq.size = 0;
    for (int rows=0;rows<MAXROWS;rows++)
    {
        for(int cols=0;cols<MAXCOLS;cols++)
        {

            if (grid[startPos.x][startPos.y] < grid[startPos.x+rows][startPos.y+cols])

            {
                return seq;
            }

            else 
            {
                maxseq.list[maxseq.size] = grid[startPos.x][startPos.y];
                maxseq.size ++;
             return generateSeq(grid, startPos, seq);
            }

        }
    }

    return maxseq;
}
4

1 回答 1

4

你没有从你的startPos- 递归永远不会停止,你很快就会崩溃堆栈。

于 2013-03-27T06:59:18.047 回答