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

【每日一题Day304】LC1267统计参与通信的服务器 | 哈希表

统计参与通信的服务器【LC1267】

这里有一幅服务器分布图,服务器的位置标识在 m * n 的整数矩阵网格 grid 中,1 表示单元格上有服务器,0 表示没有。

如果两台服务器位于同一行或者同一列,我们就认为它们之间可以进行通信。

请你统计并返回能够与至少一台其他服务器进行通信的服务器的数量。

  • 思路

    使用哈希表记录能与至少一台其他服务器进行通信的服务器坐标,那么最终结果即为哈希表的大小。

    • 首先按行遍历元素,找到能与同行服务器通信的服务器坐标,记录前一个服务器的坐标,如果不为-1,那么将前一个服务器和当前服务器添加至结果集
    • 然后按列遍历元素,找到能与同列服务器通信的服务器坐标,流程同上
  • 实现

    class Solution {public int countServers(int[][] grid) {int m = grid.length, n = grid[0].length;Set<Integer> set = new HashSet<>();for (int i = 0; i < m; i++){int pre = -1;for (int j = 0; j < n; j++){if (grid[i][j] == 1){if (pre != -1){set.add(pre);set.add(i * n + j);}pre = i * n + j;}}}for (int j = 0; j < n; j++){int pre = -1;for (int i = 0; i < m; i++){if (grid[i][j] == 1){if (pre != -1){set.add(pre);set.add(i * n + j);}pre = i * n + j;}}}return set.size();}
    }
    
    • 复杂度
      • 时间复杂度: O ( n ∗ m ) O(n*m) O(nm)
      • 空间复杂度: O ( n ∗ m ) O(n*m) O(nm)
  • 实现

    先遍历一遍矩阵,统计每行每列的服务器个数;然后再遍历一遍矩阵,如果该行或者该列服务器个数大于1,那么数量+1

    class Solution {public int countServers(int[][] grid) {int m = grid.length, n = grid[0].length;int[] row = new int[m];int[] col = new int[n];for (int i = 0; i < m; ++i) {for (int j = 0; j < n; ++j) {if (grid[i][j] == 1) {row[i]++;col[j]++;}}}int ans = 0;for (int i = 0; i < m; ++i) {for (int j = 0; j < n; ++j) {if (grid[i][j] == 1 && (row[i] > 1 || col[j] > 1)) {++ans;}}}return ans;}
    }作者:ylb
    链接:https://leetcode.cn/problems/count-servers-that-communicate/solutions/2402089/python3javacgotypescript-yi-ti-yi-jie-ji-arec/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
    
    • 复杂度
      • 时间复杂度: O ( n ∗ m ) O(n*m) O(nm)
      • 空间复杂度: O ( n + m ) O(n+m) O(n+m)
http://www.lryc.cn/news/147704.html

相关文章:

  • 深度解读零信任身份安全—— 全面身份化:零信任安全的基石
  • 音视频 ffmpeg命令提取音视频数据
  • vscode 配置
  • 企业数字化管控平台及信息化治理体系建设方案(附300份方案)
  • ABB PCD231B通信输入/输出模块
  • 在springboot项目中显示Services面板的方法
  • spring之AOP简介
  • ros::init用途用法
  • 逻辑回归的含义
  • 解决Apache Tomcat “Request header is too large“ 异常 ‍
  • 腾讯音乐如何基于大模型 + OLAP 构建智能数据服务平台
  • Java 16进制字符串转换成GBK字符串
  • 【ES6】JavaScript中的Symbol
  • 理解React页面渲染原理,如何优化React性能?
  • 数据通信——传输层TCP(可靠传输机制的滑动窗口)
  • Mycat之前世今生
  • Linux- 重定向标准输出(stdout)和标准错误(stderr)
  • PostgreSQL分区表
  • android framework之Applicataion启动流程分析(二)
  • django静态文件无法访问解决方案
  • WIndows 配置多版本python环境,非常清晰明了
  • Leetcode每日一题:1267. 统计参与通信的服务器(2023.8.24 C++)
  • c++(8.28)菱形继承,虚继承,多态,抽象类,模板+Xmind
  • 安装部署JavaFX和IDEA添加JavaFX的详细步骤
  • MAC电脑外放没有声音解决方案
  • Spring源码分析(八)CreateBean与DoCreateBean
  • iSCSI存储服务器
  • 信息技术02--初/高中--分类选择题(377道题与解析)
  • java --- 枚举类
  • nvm和volta对node版本控制的区别