-
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathmain.rs
39 lines (37 loc) · 1.33 KB
/
main.rs
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
pub fn main() {
let d = include_bytes!("../input.txt");
let s = d.iter().position(|b| b == &b'\n').unwrap();
let g: Vec<&[u8]> = d.split(|b| b == &b'\n').filter(|l| !l.is_empty()).collect();
let mut max = 0;
for x in 0..s {
for y in 0..s {
let cur = g[y][x];
if cur <= 1 {
continue;
}
max = max.max(
((1..y)
.map(|yy| g[y - yy][x])
.position(|h| h >= cur)
.unwrap_or_else(|| y.wrapping_sub(1))
.wrapping_add(1))
* ((y + 1..s)
.map(|y| g[y][x])
.position(|h| h >= cur)
.unwrap_or_else(|| (s - y).wrapping_sub(2))
.wrapping_add(1))
* ((1..x)
.map(|xx| g[y][x - xx])
.position(|h| h >= cur)
.unwrap_or_else(|| x.wrapping_sub(1))
.wrapping_add(1))
* ((x + 1..s)
.map(|x| g[y][x])
.position(|h| h >= cur)
.unwrap_or_else(|| (s - x).wrapping_sub(2))
.wrapping_add(1)),
);
}
}
println!("{}", max);
}