-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathNumber of Laser Beams in a Bank.cpp
40 lines (30 loc) · 1.25 KB
/
Number of Laser Beams in a Bank.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
Solution by Rahul Surana
***********************************************************
Anti-theft security devices are activated inside a bank.
You are given a 0-indexed binary string array bank representing the floor plan of the bank,
which is an m x n 2D matrix.
bank[i] represents the ith row, consisting of '0's and '1's.
'0' means the cell is empty, while'1' means the cell has a security device.
There is one laser beam between any two security devices if both conditions are met:
The two devices are located on two different rows: r1 and r2, where r1 < r2.
For each row i where r1 < i < r2, there are no security devices in the ith row.
Laser beams are independent, i.e., one beam does not interfere nor join with another.
Return the total number of laser beams in the bank.
***********************************************************
*/
class Solution {
public:
int numberOfBeams(vector<string>& bank) {
int p = 0, ans = 0;
for(int i = 0; i < bank.size(); i++){
int x = 0;
for(auto z: bank[i]) if(z=='1') x++;
ans += (p*x);
// cout << x <<" "<<p<<"\n";
if(x>0)
p = x;
}
return ans;
}
};