Leetcode每日一题:1267. 统计参与通信的服务器(2023.8.24 C++)

目录

1267. 统计参与通信的服务器

题目描述:

实现代码与解析:

写法一:两次遍历 + hash

原理思路:

写法二:三次遍历

原理思路:


1267. 统计参与通信的服务器

题目描述:

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

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

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

示例 1:

Leetcode每日一题:1267. 统计参与通信的服务器(2023.8.24 C++)_第1张图片

输入:grid = [[1,0],[0,1]]
输出:0
解释:没有一台服务器能与其他服务器进行通信。

示例 2:

Leetcode每日一题:1267. 统计参与通信的服务器(2023.8.24 C++)_第2张图片

输入:grid = [[1,0],[1,1]]
输出:3
解释:所有这些服务器都至少可以与一台别的服务器进行通信。

示例 3:

Leetcode每日一题:1267. 统计参与通信的服务器(2023.8.24 C++)_第3张图片

输入:grid = [[1,1,0,0],[0,0,1,0],[0,0,1,0],[0,0,0,1]]
输出:4
解释:第一行的两台服务器互相通信,第三列的两台服务器互相通信,但右下角的服务器无法与其他服务器通信。

提示:

  • m == grid.length
  • n == grid[i].length
  • 1 <= m <= 250
  • 1 <= n <= 250
  • grid[i][j] == 0 or 1

实现代码与解析:

写法一:两次遍历 + hash

class Solution {
public:
    int countServers(vector>& grid) {

        unordered_map row, col;  
        for (int i = 0; i < grid.size(); i++)
        {
            for (int j = 0; j < grid[0].size(); j++)
            {
                if (grid[i][j] == 1)
                {
                    row[i]++;
                    col[j]++;
                }
            }
        }

        int res = 0;
        for (int i = 0; i < grid.size(); i++)
            for (int j = 0; j < grid[0].size(); j++)
                if (grid[i][j] == 1 && (row[i] > 1 || col[j] > 1)) res++;
        
        return res;
    }
};

原理思路:

        第一次遍历hash记录每一行每一列的有的1的个数。

        第二次遍历如果此位置有1,而且行或列有的服务器个数大于1,res++。

        返回结果。

写法二:三次遍历

class Solution {
public:
    int countServers(vector>& grid) {

        int res = 0;
        vector row(grid.size(), false);
        vector col(grid[0].size(), false);

        // 每行符合条件的
        for (int i = 0; i < grid.size(); i++)
        {
            int count = 0;
            for (int j = 0; j < grid[0].size(); j++)
                if (grid[i][j] == 1) count++;

            if (count > 1)
            {
                row[i] = true;
                res += count;
            }

        }

        // 每列符合条件的
        for (int i = 0; i < grid[0].size(); i++)
        {
            int count = 0;
            for (int j = 0; j < grid.size(); j++)
                if (grid[j][i] == 1) count++;

            if (count > 1)
            {
                col[i] = true;
                res += count;
            }
        }

        int repeat = 0; 
        // 重复的
        for (int i = 0; i < grid.size(); i++)
            for (int j = 0; j < grid[0].size(); j++)
                if (row[i] && col[j] && grid[i][j] == 1) repeat++;

        return res - repeat;
    }
};

原理思路:

        不用hash的写法。

        第一次遍历行种符合条件的。

        第二次遍历列中符合条件的。

        第三次遍历重复计算的。

        返回结果减去重复计算。

你可能感兴趣的:(Leetcode,算法,数据结构,leetcode)