对像素点的处理,中间的点取和周围四个的平均值,边上的不变

#include
#include
int main()
{
int a[10][10],
i,j,n,m;
while(scanf("%d %d",&m,&n)!=EOF)
{
for(i=0; i
for(j=0; j
scanf("%d",(a+i)+j);

if(i!=0||j!=0||i!=m-1||j!=n-1)
a[i][j]=(a[i-1][j]+a[i][j-1]+a[i+1][j]+a[i][j+1]+a[i][j])/5;
else
a[i][j]=a[i][j];

    for(i=0; ifor(j=0; j"%d ",a[i][j]);
        }
        printf("\n");
    }
 m=0;
 n=0;
}
return 0;

}
输出的结果很大,怎么回事?

for(i=0; i<m; i++)
     for(j=0; j<n; j++)
           scanf("%d",(a+i)+j);
for(i=0; i<m; i++)
     for(j=0; j<n; j++)
     {
           if(i!=0||j!=0||i!=m-1||j!=n-1)
                   a[i][j]=(a[i-1][j]+a[i][j-1]+a[i+1][j]+a[i][j+1]+a[i][j])/5;
     }

1.你要先把所有的点读完了再循环计算,不要后面的点还没有赋值你就拿来做计算
2.for(i=1;i<m-1;i++)就能保证i不越界了,没必要再加个if来判断