所以我有这个功能,它使用递归来找到最长的数字序列。但是每次我运行它时,我都会收到以下错误消息:
增加的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
前进-递归永远不会停止,您会很快使堆栈崩溃。