我试图编写一个代码来获得数组的修补程序/子窗口。我编写了以下代码:
#include <stdio.h>
int patch(int a[5][5],int b[2][2],int r,int s)
{
int i=0,j=0,k;
if(r<=(5-2) && s<=(5-2)){
for(r;r<(r+2);r++){
for(s;s<(s+2);s++)
{
k = a[r][s];
b[i][j] = k;
i = i+1;
j = j+1;
}
}
}
else
{printf("error!");}
return 0;
}
int main()
{
int i,j,p,q;
int y[2][2] = {0};
int x[5][5] = {{95,155,200,200,232},
{100,155,232,95,150},
{200,45,200,135,123},
{232,150,85,69,180},
{95,95,200,123,45}
};
for(i=0;i<5;i++){
for(j=0;j<5;j++){
patch(x,y,i,j);
for(p=0;p<2;p++){
for(q=0;q<2;q++)
{
printf("y[%d][%d] = %d\n",p,q,y[p][q]);
}
}
}
}
return 0;
}
但是,一旦运行并编译了这段代码,就会出现一个错误,说明program.exe已停止工作。我怎么才能解决这个问题?对于这种进程,我需要使用动态内存分配吗?还是有更简单的解决方案。
发布于 2014-04-06 13:39:20
这一行:
for(r;r<(r+2);r++)
将运行的时间比您预期的长得多,从而导致缓冲区溢出。我认为您的意思是在启动循环之前保存r+2
,然后与之进行比较。
另外,您将增加4次i
和j
,因此您也可以访问b
的范围。你需要重新思考你的循环逻辑。也许应该是:
for (i = 0 ; i < 2; i++)
for (j = 0; j < 2; j++)
{
b[i][j] = a[r+i][s+j];
}
https://stackoverflow.com/questions/22894718
复制相似问题