Skip to content

Commit 74a84df

Browse files
committed
Create: 0554-brick-wall.rs
1 parent 9d4c0f4 commit 74a84df

File tree

1 file changed

+28
-0
lines changed

1 file changed

+28
-0
lines changed

rust/0554-brick-wall.rs

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
use std::collections::HashMap;
2+
impl Solution {
3+
pub fn least_bricks(wall: Vec<Vec<i32>>) -> i32 {
4+
wall.len() as i32
5+
- wall
6+
.into_iter()
7+
.map(|row| {
8+
let mut prefix: Vec<_> = row
9+
.into_iter()
10+
.scan(0, |sum, x| {
11+
*sum += x;
12+
Some(*sum)
13+
})
14+
.collect();
15+
prefix.pop();
16+
prefix
17+
})
18+
.flatten()
19+
.fold(HashMap::from([(0, 0)]), |mut acc, x| {
20+
acc.entry(x).and_modify(|cnt| *cnt += 1).or_insert(1);
21+
acc
22+
})
23+
.into_iter()
24+
.map(|(_, v)| v)
25+
.max()
26+
.unwrap()
27+
}
28+
}

0 commit comments

Comments
 (0)