LeetCode 2125.银行中的激光束数量

银行内部的防盗安全装置已经激活。给你一个下标从 0 开始的二进制字符串数组 bank ,表示银行的平面图,这是一个大小为 m x n 的二维矩阵。 bank[i] 表示第 i 行的设备分布,由若干 '0' 和若干 '1' 组成。'0' 表示单元格是空的,而 '1' 表示单元格有一个安全设备。

对任意两个安全设备而言,如果同时 满足下面两个条件,则二者之间存在 一个 激光束:

两个设备位于两个 不同行 :r1 和 r2 ,其中 r1 < r2 。

满足 r1 < i < r2 的 所有 行 i ,都 没有安全设备 。

激光束是独立的,也就是说,一个激光束既不会干扰另一个激光束,也不会与另一个激光束合并成一束。

返回银行中激光束的总数量。

示例 1:

输入:bank = ["011001","000000","010100","001000"]

输出:8

解释:在下面每组设备对之间,存在一条激光束。总共是 8 条激光束:

  • bank[0][1] -- bank[2][1]
  • bank[0][1] -- bank[2][3]
  • bank[0][2] -- bank[2][1]
  • bank[0][2] -- bank[2][3]
  • bank[0][5] -- bank[2][1]
  • bank[0][5] -- bank[2][3]
  • bank[2][1] -- bank[3][2]
  • bank[2][3] -- bank[3][2]
    注意,第 0 行和第 3 行上的设备之间不存在激光束。
    这是因为第 2 行存在安全设备,这不满足第 2 个条件。
    示例 2:

输入:bank = ["000","111","000"]

输出:0

解释:不存在两个位于不同行的设备

提示:

m == bank.length

n == bank[i].length

1 <= m, n <= 500

bank[i][j] 为 '0' 或 '1'

直接模拟即可:

cpp 复制代码
class Solution {
public:
    int numberOfBeams(vector<string>& bank) {
        int ans = 0;
        int last = 0;
        for (string &row : bank)
        {
            int deviceNum = count(row.begin(), row.end(), '1');
            if (deviceNum == 0)
            {
                continue;
            }
            ans += deviceNum * last;
            last = deviceNum;
        }

        return ans;
    }
};
相关推荐
美好的事情能不能发生在我身上几秒前
Leetcode热题100中的:技巧专题
算法·leetcode·职场和发展
荣光属于凯撒2 分钟前
P15755 [JAG 2025 Summer Camp #1] JAG Box
c++·算法·贪心算法
2301_803554523 分钟前
单例模式以及面试可能问的--精写
单例模式·面试·职场和发展
郝学胜-神的一滴10 分钟前
CMake:解锁C++跨平台工程构建的核心密钥
开发语言·c++·职场和发展
AI科技星16 分钟前
基于v≡c空间光速螺旋量子几何归一化统一场论第一性原理的时间势差本源理论
人工智能·线性代数·算法·机器学习·平面
云泽80820 分钟前
蓝桥杯算法精讲:哈夫曼编码的贪心思想与落地实现
算法·职场和发展·蓝桥杯
x_xbx26 分钟前
LeetCode:53. 最大子数组和
算法·leetcode·职场和发展
菜菜小狗的学习笔记27 分钟前
剑指Offer算法题(一)数组与矩阵
线性代数·算法·矩阵
仰泳的熊猫33 分钟前
题目2269:蓝桥杯2016年第七届真题-冰雹数
开发语言·数据结构·c++·算法·蓝桥杯
冷徹 .34 分钟前
2023ICPC山东省赛
c++·算法