我正在尝试编写代码来获取数组的补丁/子窗口。我写了以下代码:
#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已停止工作。我怎样才能解决这个问题 ?我是否需要为这种过程使用动态内存分配?或者是否有更简单的解决方案。
答案 0 :(得分:6)
这一行:
for(r;r<(r+2);r++)
运行的时间比你预期的要长很多,导致缓冲区溢出。我认为你的意思是在开始循环之前保存r+2
,然后与之进行比较。
此外,您将增加i
和j
4次,因此您也可以访问b
的范围。你需要重新思考你的循环逻辑。也许它应该是:
for (i = 0 ; i < 2; i++)
for (j = 0; j < 2; j++)
{
b[i][j] = a[r+i][s+j];
}