900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > 【信息学奥赛课课通】最大黑区域

【信息学奥赛课课通】最大黑区域

时间:2020-02-21 02:53:01

相关推荐

【信息学奥赛课课通】最大黑区域

题目描述

二值图像是由黑白两种像素组成的矩形点阵,图像识别的一个操作是求出图像中最大黑区域的面积。请设计一个程序完成二值图像的这个操作。黑区域由黑像素组成,一个黑区域中的每像素至少与该区域中的另一像素相邻,规定一个像素仅与其上、下、左、右的像素相邻。两个不同的黑区域没有相邻的像素。一个黑区域的面积是其所包含的像素数。

输入

第 1 行含两个正整数 n 和 m,1≤n、m≤100,分别表示二值图像的行数与列数,后面紧跟着n 行,每行含 m 个整数 0 或 1,其中第 i 行表示图像的第 i 行的 m 个像素,0 表示白像素,1 表示黑像素。

输出

输出一个数,表示相应的图像中最大黑区域的面积。

样例输入

5 60 1 1 0 0 11 1 0 1 0 10 1 0 0 1 00 0 0 1 1 11 0 1 1 1 0

样例输出

7

循环,若此元素未被标记则进行搜索,每搜到一个标记一下,并将计数器++,最后输出

代码:

#include <bits/stdc++.h>using namespace std;char a[101][101];int sum, ans, n, m;void dg(int x, int y){if (a[x][y] == '1'){a[x][y] = '0';sum++;}if (a[x + 1][y] == '1')dg(x + 1, y);if (a[x - 1][y] == '1')dg(x - 1, y);if (a[x][y + 1] == '1')dg(x, y + 1);if (a[x][y - 1] == '1')dg(x, y - 1);}main(){freopen("area.in","r",stdin);freopen("area.out","w",stdout);scanf("%d%d", &n, &m);for (int i = 1; i <= n; i++){for (int j = 1; j <= m; j++){cin >> a[i][j];}}for (int i = 1; i <= n; i++){for (int j = 1; j <= m; j++){if (a[i][j] == '1'){sum = 0;dg(i, j);ans = max(sum, ans);}}}printf("%d", ans);return 0;}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。