全新题目
【题目难度 | 中等】※※※
【编程题目 |200分】图像物体的边界【2022 Q2考试题】
时间限制:C/C++ 1秒,其他语言 2秒
空间限制:C/C++262144K,其他语言524288K
64bit IO Format:%lld
本题可使用本地IDE编码,不能使用本地已有代码,无跳出限制,
编码后请点击”保存并调试“按钮进行代码提交。
■ 题目描述
【图像物体的边界】
给定一个二维数组M行N列,二维数组里的数字代表图片的像素,为了简化问题,仅包含像素1和5两种像素,每种像素代表一个物体,2个物体相邻的格子为边界,求像素1代表的物体的边界个数。
像素1代表的物体的边界指与像素5相邻的像素1的格子,边界相邻的属于同一个边界,相邻需要考虑8个方向(上,下,左,右,左上,左下,右上,右下)。
其他约束
地图规格约束为:
0<M<100
0<N<100
1)如下图,与像素5的格子相邻的像素1的格子(0,0)、(0,1)、(0,2)、(1,0)、(1,2)、(2,0)、(2,1)、(2,2)、(4,4)、(4,5)、(5,4)为边界,另(0,0)、(0,1)、(0,2)、(1,0)、(1,2)、(2,0)、(2,1)、(2,2)相邻,为1个边界,(4,4)、(4,5)、(5,4)相邻,为1个边界,所以下图边界个数为2。
2)如下图,与像素5的格子相邻的像素1的格子(0,0)、(0,1)、(0,2)、(1,0)、(1,2)、(2,0)、(2,1)、(2,2)、(3,3)、(3,4)、(3,5)、(4,3)、(4,5)、(5,3)、(5,4)、(5,5)为边界,另这些边界相邻,所以下图边界个数为1。
注:(2,2)、(3,3)相邻。
输入描述
第一行,行数M,列数N
第二行开始,是M行N列的像素的二维数组,仅包含像素1和5
输出描述
像素1代表的物体的边界个数。
如果没有边界输出0(比如只存在像素1,或者只存在像素5)。
示例1 输入输出示例仅供调试,后台判题数据一般不包含示例
输入
6 6
1 1 1 1 1 1
1 5 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 5
输出
2
说明
参考题目描述部分
示例2 输入输出示例仅供调试,后台判题数据一般不包含示例
输入
6 6
1 1 1 1 1 1
1 5 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 5 1
1 1 1 1 1 1
输出
1
说明
参考题目描述部分
代码实现
C++
#include<bits/stdc++.h> using namespace std;
剩余50%内容,订阅会员后查看
此处内容需要权限查看
会员免费查看JAVA
import java.util.Scanner; public class ImagePixel { public static int hang; public static int lie; public static int[][] ints;
剩余50%内容,订阅会员后查看
此处内容需要权限查看
会员免费查看Python解法一
剩余50%内容,订阅会员后查看
此处内容需要权限查看
会员免费查看Python解法二
m, n = input().split() map = [input().split() for _ in range(int(m))]
剩余50%内容,订阅会员后查看
此处内容需要权限查看
会员免费查看JavaScript
var hang = Number(readLine()); var lie = Number(readLine()); // var hang = Number("6"); // var lie = Number("6"); var ints = []; // var ints = [[1,1,1,1,1,1], // [1,5,1,1,1,1], // [1,1,1,1,1,1], // [1,1,1,1,1,1], // [1,1,1,1,1,1], // [1,1,1,1,1,5]];
剩余50%内容,订阅会员后查看
此处内容需要权限查看
会员免费查看