鱼C论坛

 找回密码
 立即注册
查看: 2778|回复: 6

[已解决]一道C语言程序题

[复制链接]
发表于 2020-4-20 05:43:12 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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
最佳答案
2020-4-20 14:54:04
num的作用是统计输入坐标周围元素个数,用不到的话,就把num相关的都删掉就可以了。
  1. #include<stdio.h>
  2. int main()
  3. {
  4.     int rows,cols;
  5.     int i,j;
  6.     int row,col,result=0,num=0;
  7.     scanf("%d%d",&rows,&cols);
  8.     int ar[rows][cols];
  9.     for (i=0;i<rows;i++)
  10.         for (j=0;j<cols;j++)
  11.             scanf("%d",&ar[i][j]);
  12.    
  13.     scanf("%d%d",&row,&col);
  14.     if (row>rows||col>cols||row<1||col<1){
  15.         printf("输入范围错误!\n");
  16.         return 0;
  17.     }
  18.     if (row>1){//若输入的位置不是第一行
  19.         result+=ar[row-2][col-1];//当前位置的上一行必定有元素
  20.         num+=1;
  21.         if (col>1){//若输入的位置不是第一列
  22.             result+=ar[row-2][col-2];//当前位置的左上角必有元素
  23.             result+=ar[row-1][col-2];//当前位置的左侧必有元素
  24.             num+=2;
  25.         }
  26.         if (col<cols){//若输入的位置不是最后一列
  27.             result+=ar[row-2][col];//当前位置右上角必有元素
  28.             result+=ar[row-1][col];//当前位置右侧必有元素
  29.             num+=2;
  30.         }
  31.     }
  32.     else{//若输入的位置是第一行
  33.         if (col>1){//若输入的位置不是第一列
  34.             result+=ar[row-1][col-2];//当前位置的左侧必有元素
  35.             num+=1;
  36.         }
  37.         if (col<cols){//若输入的位置不是最后一列
  38.             result+=ar[row-1][col];//当前位置右侧必有元素
  39.             num+=1;
  40.         }
  41.     }
  42.     if(row<rows){//若输入的位置不是最后一行
  43.         result+=ar[row][col-1];//当前位置下方必有元素
  44.         num+=1;
  45.         if(col>1){//若输入的位置不是第一列
  46.             result+=ar[row][col-2];//当前位置左下方必有元素
  47.             num+=1;
  48.         }
  49.         if (col<cols){//若输入的位置不是最后一列
  50.             result+=ar[row][col];//当前位置右下方必有元素
  51.             num+=1;
  52.         }
  53.     }

  54.     //printf("该位置周围有%d个元素,各个元素之和为%d\n",num,result);
  55.     printf("%d",result);
  56.     return 0;
  57. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-20 07:14:05 | 显示全部楼层
题目网址发一下
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-20 09:13:06 | 显示全部楼层
很简单呀~
1,用一个二维数组
2,把数字输入进二位数组
3,然后判断他是在边缘,在角落,还是在中间
4,再找到它周围的数
5,做加法
6,输出
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-20 14:54:04 | 显示全部楼层    本楼为最佳答案   
num的作用是统计输入坐标周围元素个数,用不到的话,就把num相关的都删掉就可以了。
  1. #include<stdio.h>
  2. int main()
  3. {
  4.     int rows,cols;
  5.     int i,j;
  6.     int row,col,result=0,num=0;
  7.     scanf("%d%d",&rows,&cols);
  8.     int ar[rows][cols];
  9.     for (i=0;i<rows;i++)
  10.         for (j=0;j<cols;j++)
  11.             scanf("%d",&ar[i][j]);
  12.    
  13.     scanf("%d%d",&row,&col);
  14.     if (row>rows||col>cols||row<1||col<1){
  15.         printf("输入范围错误!\n");
  16.         return 0;
  17.     }
  18.     if (row>1){//若输入的位置不是第一行
  19.         result+=ar[row-2][col-1];//当前位置的上一行必定有元素
  20.         num+=1;
  21.         if (col>1){//若输入的位置不是第一列
  22.             result+=ar[row-2][col-2];//当前位置的左上角必有元素
  23.             result+=ar[row-1][col-2];//当前位置的左侧必有元素
  24.             num+=2;
  25.         }
  26.         if (col<cols){//若输入的位置不是最后一列
  27.             result+=ar[row-2][col];//当前位置右上角必有元素
  28.             result+=ar[row-1][col];//当前位置右侧必有元素
  29.             num+=2;
  30.         }
  31.     }
  32.     else{//若输入的位置是第一行
  33.         if (col>1){//若输入的位置不是第一列
  34.             result+=ar[row-1][col-2];//当前位置的左侧必有元素
  35.             num+=1;
  36.         }
  37.         if (col<cols){//若输入的位置不是最后一列
  38.             result+=ar[row-1][col];//当前位置右侧必有元素
  39.             num+=1;
  40.         }
  41.     }
  42.     if(row<rows){//若输入的位置不是最后一行
  43.         result+=ar[row][col-1];//当前位置下方必有元素
  44.         num+=1;
  45.         if(col>1){//若输入的位置不是第一列
  46.             result+=ar[row][col-2];//当前位置左下方必有元素
  47.             num+=1;
  48.         }
  49.         if (col<cols){//若输入的位置不是最后一列
  50.             result+=ar[row][col];//当前位置右下方必有元素
  51.             num+=1;
  52.         }
  53.     }

  54.     //printf("该位置周围有%d个元素,各个元素之和为%d\n",num,result);
  55.     printf("%d",result);
  56.     return 0;
  57. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-21 17:51:34 | 显示全部楼层

啊……这个是在学校oj平台上发布的测试题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-21 17:53:06 | 显示全部楼层
sunrise085 发表于 2020-4-20 14:54
num的作用是统计输入坐标周围元素个数,用不到的话,就把num相关的都删掉就可以了。

哇注释好详细啊~看明白了,谢谢大佬!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-21 19:56:19 | 显示全部楼层
liuzhengyuan 发表于 2020-4-20 09:13
很简单呀~
1,用一个二维数组
2,把数字输入进二位数组

确实简单(捂脸)我当时没转过弯来,蟹蟹帮助~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-30 09:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表