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


  增加的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;
}

最佳答案

您没有从startPos前进-递归永远不会停止,您会很快使堆栈崩溃。

09-27 03:19