7-19 矩阵元素有条件求和 (15 分)
给定一个 m 行 n 列的二维数组,请找出这个二维数组中唯一的一个值为0的元素,并将其直接相邻的八个方向上的元素值全部变成0,然后再求这个矩阵中所有数的和。 直接相邻的八个方向包括:上、下、左、右、左上、左下、右上和右下。超过数组边界的忽略。 数据保证有且只有一个0元素。
输入格式:
先输入m和n代表二维矩阵的行数和列数,5<= m,n <=100 然后输入每行,每行n个整数,以空格分隔。
输出格式:
输出修改之后的二维数组的所有元素的和,输出数据之后需要输出回车换行。
输入样例:
在这里给出一组输入。例如:
5 5
1 2 3 4 5
1 2 3 4 5
1 2 0 4 5
1 2 3 4 5
1 2 3 4 5
结尾无空行
输出样例:
在这里给出相应的输出。例如:
48
结尾无空行
#include<stdio.h>
int main()
{
int m,n,i,j,s,r,c;
scanf("%d %d",&m,&n);
int a[m][n];
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
scanf("%d",&a[i][j]);
if(a[i][j]==0)
{
r=i;
c=j;
}
}
}
s=0;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
if(!(i>=r-1&&i<=r+1&&j<=c+1&&j>=c-1))
{
s+=a[i][j];
}
}
}
printf("%d",s);
return 0;
}
#include<stdio.h>
int main()
{
int m,n,i,j,r,c,f,s=0;
scanf("%d%d",&m,&n);
int a[m][n];
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
scanf("%d",&a[i][j]);
}
}
for(i=0;i<m;i++)
{
f=0;
for(j=0;j<n;j++)
{
if(a[i][j]==0)
{
r=i;
c=j;
f=1;
break;
}
}
if(f==1)
break;
}
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
if(!(i>=r-1&&i<=r+1&&j>=c-1&&j<=c+1))
s+=a[i][j];
}
}
printf("%d",s);
return 0;
}