|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
刚接触C语言,完全没有思路,希望大佬们能帮帮忙!
题目描述
现有一个矩阵,请你写程序求出某个数周围数字的和。这里我们规定,矩阵的左上角坐标为(1,1),它右边一行的数的坐标依次为(1,2)、(1,3)等等,它下边一列的数的坐标依次为(2,1)、(3,1)等等,其余坐标以此类推。
输入:
第一行为两个整数m,n(1<m,n<10),分别代表矩阵的行和列数。
接下来是m行n列整数,最后一行是两个整数x,y,分别代表指定的坐标。
输出:
为一个整数,为指定坐标周围的数字的和。需要注意的是当指定坐标在矩阵中间时,它周围有8个数,当它在矩阵边缘时它周围有5个数,当它在矩阵角上时它周围只有3个数。测试用例保证合法且所有整数可以用int存储。
输入样例
5 6
1 2 3 4 5 6
7 8 9 10 11 12
13 14 15 16 17 18
19 20 21 22 23 24
25 26 27 28 29 30
2 2
输出样例
64
num的作用是统计输入坐标周围元素个数,用不到的话,就把num相关的都删掉就可以了。
- #include<stdio.h>
- int main()
- {
- int rows,cols;
- int i,j;
- int row,col,result=0,num=0;
- scanf("%d%d",&rows,&cols);
- int ar[rows][cols];
- for (i=0;i<rows;i++)
- for (j=0;j<cols;j++)
- scanf("%d",&ar[i][j]);
-
- scanf("%d%d",&row,&col);
- if (row>rows||col>cols||row<1||col<1){
- printf("输入范围错误!\n");
- return 0;
- }
- if (row>1){//若输入的位置不是第一行
- result+=ar[row-2][col-1];//当前位置的上一行必定有元素
- num+=1;
- if (col>1){//若输入的位置不是第一列
- result+=ar[row-2][col-2];//当前位置的左上角必有元素
- result+=ar[row-1][col-2];//当前位置的左侧必有元素
- num+=2;
- }
- if (col<cols){//若输入的位置不是最后一列
- result+=ar[row-2][col];//当前位置右上角必有元素
- result+=ar[row-1][col];//当前位置右侧必有元素
- num+=2;
- }
- }
- else{//若输入的位置是第一行
- if (col>1){//若输入的位置不是第一列
- result+=ar[row-1][col-2];//当前位置的左侧必有元素
- num+=1;
- }
- if (col<cols){//若输入的位置不是最后一列
- result+=ar[row-1][col];//当前位置右侧必有元素
- num+=1;
- }
- }
- if(row<rows){//若输入的位置不是最后一行
- result+=ar[row][col-1];//当前位置下方必有元素
- num+=1;
- if(col>1){//若输入的位置不是第一列
- result+=ar[row][col-2];//当前位置左下方必有元素
- num+=1;
- }
- if (col<cols){//若输入的位置不是最后一列
- result+=ar[row][col];//当前位置右下方必有元素
- num+=1;
- }
- }
- //printf("该位置周围有%d个元素,各个元素之和为%d\n",num,result);
- printf("%d",result);
- return 0;
- }
复制代码
|
|