当前位置: 首页 > news >正文

【大厂机试题解法笔记】可以组成网络的服务器

在一个机房中,服务器的位置标识在 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]三台服务器相互连接,可以组成局域网

思考

矩阵中相邻的1构成局域网,统计所有局域网中最大的。遍历矩阵,判断如果是 1 就 DFS 搜索周围的1,搜索过程中的统计 1 的数目,直到没有1或遇到矩阵边界时结束一轮 DFS,将本轮统计的局域网大小(1的数量)更新结果变量,取最大值。完成所有遍历和搜索,得到最大局域网数量。

算法过程

  1. 输入处理

    • 读取矩阵的行数 n 和列数 m
    • 逐行读取矩阵数据,存储为二维数组 mtx
  2. 初始化辅助结构

    • 创建与矩阵大小相同的 visited 数组,用于标记已访问的服务器
    • 初始化 maxCount 记录最大局域网服务器数量
  3. 深度优先搜索(DFS)

    • 终止条件:超出矩阵边界、当前位置无服务器或已访问
    • 标记当前服务器:将当前位置标记为已访问
    • 递归探索:向上下左右四个方向递归搜索相连的服务器
    • 返回值:当前局域网的服务器总数
  4. 遍历矩阵

    • 对每个位置 (i, j)
      • 若存在未访问的服务器(mtx[i][j] == 1 且未被访问)
      • 启动 DFS 计算当前局域网大小
      • 更新最大局域网大小 maxCount
  5. 遍历结束后,maxCount 即为最大局域网的服务器数量。时间复杂度为 O (n*m)。

参考代码

function solution() {const [n, m] = readline().split(' ').map(Number);const mtx = Array(n);for (let i = 0; i < n; i++) {mtx[i] = readline().split(" ").map(Number);}const visited = Array.from({length: n}, () => new Array(m).fill(false));let maxCount = 0;const dfs = function(x, y) {if (x < 0 || x >= n || y < 0 || y >= m || mtx[x][y] !==1 || visited[x][y]) {return 0;}visited[x][y] = true;let count = 1;count += dfs(x-1, y);count += dfs(x+1, y);count += dfs(x, y-1);count += dfs(x, y+1);return count;};for (let i = 0; i < n; i++) {for (let j = 0; j < m; j++) {if (mtx[i][j] === 1 && !visited[i][j]) {const count = dfs(i, j);maxCount = Math.max(maxCount, count);}}}console.log(maxCount);
}const cases = [`2 2
1 0
1 1`
];let caseIndex = 0;
let lineIndex = 0;const readline = (function () {let lines = [];return function () {if (lineIndex === 0) {lines = cases[caseIndex].trim().split("\n").map((line) => line.trim());}return lines[lineIndex++];};
})();cases.forEach((_, i) => {caseIndex = i;lineIndex = 0;solution();
});

http://www.lqws.cn/news/519301.html

相关文章:

  • FPGA基础 -- Verilog 格雷码(Gray Code)计数器设计与原理解析
  • 开疆智能CCLinkIE转ModbusTCP网关连接脉冲计数器配置案例
  • MySQL之存储过程详解
  • 自动化测试--Appium和ADB及常用指令
  • 分布式环境下 Spring Boot 项目基于雪花算法的唯一 ID 生成方案
  • php后台增加权限控制
  • LangGraph开篇-LangGraph 核心元素简介(官网文档解读)
  • Spring Web MVC ①
  • 用 Boost 库解析 .ini 和 .json 文件时的“坑”:注释导致的解析错误与解决方案
  • 湖北理元理律师事务所:债务规划中的法律与心理双轨模型
  • 如何在 Manjaro Linux 上安装 Docker 容器
  • OpenCV——cv::floodFill
  • 卷积神经网络(Convolutional Neural Network, CNN)
  • 使用pyflink编写demo并将任务提交到yarn集群
  • 大塘至浦北高速:解锁分布式光伏“交能融合”密码,引领绿色交通革命
  • Redis HyperLogLog误差率0.81%的由来:从算法原理到Redis实现
  • UNIAPP入门基础
  • 如何快速将iPhone中的文本保存到电脑上
  • [架构之美]在Linux上通过源码编译安装Nginx(十四)
  • golang实现一个mysql中随机获取cookies的API
  • 数字隔离器,如何扛起现代智能家电的电气安全“大旗”
  • [Java实战]Windows系统JDK21安装与JDK8切换指南(三十九)
  • 利用亮数据实现海外网站数据自动抓取
  • 回归预测 | Matlab实现KAN神经网络多输入单输出回归预测模型
  • 【CUDA调优指南】缓存访存流程
  • 商务年度总结汇报PPT模版分享
  • 板凳-------Mysql cookbook学习 (十--10)
  • 笔记02:布线-差分对的设置与添加
  • 定制开发开源AI智能名片与S2B2C商城小程序的内容分发体系构建:基于“1+N“素材复用模型的创新实践
  • 旧物回收小程序:让旧物重获新生的魔法钥匙