【机试刷题】华为OD-可以组成网络的服务器
题目描述
在一个机房中,服务器的位置标识在 n*m 的整数矩阵网格中,1 表示单元格上有服务器,0 表示没有。如果两台服务器位于同一行或者同一列中紧邻的位置,则认为它们之间可以组成一个局域网。
请你统计机房中最大的局域网包含的服务器个数。
输入描述
第一行输入两个正整数,n和m,0<n,m<=100
之后为n*m的二维数组,代表服务器信息
输出描述
最大局域网包含的服务器个数。
用例
输入 | 2 2 1 0 1 1 |
输出 | 3 |
说明 | [0][0]、[1][0]、[1][1]三台服务器相互连接,可以组成局域网 |
参考
#include <iostream>
using namespace std;
int n, m;//n表示行数,m表示列数
int server[100][100]; // 定义一个矩阵,用于存储服务器的状态
// 定义一个深度优先搜索函数,用于搜索当前位置的连通块大小
int dfs(int i, int j, int count) {
//如果当前位置没有服务器, 或者当前位置超出矩阵边界,则返回当前连通块大小
if (i < 0 || i >= n || j < 0 || j >= m || server[i][j] == 0)
{
return count;
}
// 如果当前位置有服务器,则将其状态改为0,表示已经搜索过
count++;
server[i][j] = 0;//标记已经搜索过,防止以后重复搜。
// 分别向上、下、左、右四个方向递归搜索,并累加连通块大小
count = dfs(i - 1, j, count); // 上
count = dfs(i + 1, j, count); // 下
count = dfs(i, j - 1, count); // 左
count = dfs(i, j + 1, count); // 右
return count;
}
int main() {
// 读入矩阵的行数和列数
cin >> n >> m;
// 读入矩阵中每个位置的状态(0表示没有服务器,1表示有服务器)
for (int i = 0; i < n; i ) {
for (int j = 0; j < m; j ) {
cin >> server[i][j];
}
}
int ans = 0; // 定义一个变量,用于存储最大连通块大小
// 枚举矩阵中的每个位置,以该位置为起点进行深度优先搜索,并更新最大连通块大小
for (int i = 0; i < n; i ) {
for (int j = 0; j < m; j ) {
ans = max(ans, dfs(i, j, 0));
}
}
// 输出最大连通块大小
cout << ans << endl;
return 0;
}