题目描述
二值图像是由黑白两种像素组成的矩形点阵,图像识别的一个操作是求出图像中最大黑区域的面积。请设计一个程序完成二值图像的这个操作。黑区域由黑像素组成,一个黑区域中的每像素至少与该区域中的另一像素相邻,规定一个像素仅与其上、下、左、右的像素相邻。两个不同的黑区域没有相邻的像素。一个黑区域的面积是其所包含的像素数。
输入
第 1 行含两个正整数 n 和 m,1≤n、m≤100,分别表示二值图像的行数与列数,后面紧跟着n 行,每行含 m 个整数 0 或 1,其中第 i 行表示图像的第 i 行的 m 个像素,0 表示白像素,1 表示黑像素。
输出
输出一个数,表示相应的图像中最大黑区域的面积。
样例输入
5 6 0 1 1 0 0 1 1 1 0 1 0 1 0 1 0 0 1 0 0 0 0 1 1 1 1 0 1 1 1 0
样例输出
7
时间限制: 1 Sec 内存限制: 128 MB
这一题是一道比较基础且比较经典的深度优先搜索题
主函数部分如果学过二维数组保存的应该都会吧:
cin>>n>>m;//输入行数列数
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];//保存二维数组
}
}
这里为输入部分
开始dfs时要在循环中一直查找,并且不能在输入中。
for(int i=1;i<=n;i&