-
Notifications
You must be signed in to change notification settings - Fork 111
/
Copy pathstrange-printer-ii.rs
35 lines (35 loc) · 1.23 KB
/
strange-printer-ii.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
// Strange Printer II
impl Solution {
pub fn is_printable(grid: Vec<Vec<i32>>) -> bool {
use std::collections::HashSet;
fn cycle(u: usize, vis: &mut Vec<usize>, adj: &Vec<HashSet<usize>>) -> bool {
vis[u] = 1;
if adj[u].iter().any(|&v| vis[v] == 1 || vis[v] == 0 && cycle(v, vis, adj)) {
return true;
}
vis[u] = 2;
false
}
let nc = 61;
let m = grid.len();
let n = grid[0].len();
let mut adj: Vec<HashSet<usize>> = vec![HashSet::new(); nc];
for c in 1..nc {
let mut x0 = m; let mut x1 = 0;
let mut y0 = n; let mut y1 = 0;
for i in 0..m {
for j in 0..n {
if grid[i][j] == c as i32 {
x0 = x0.min(i);
x1 = x1.max(i);
y0 = y0.min(j);
y1 = y1.max(j); }}}
for i in x0..x1+1 {
for j in y0..y1+1 {
if grid[i][j] != c as i32 {
adj[c].insert(grid[i][j] as usize); }}}
}
let mut vis = vec![0; nc];
!(1..nc).any(|c| vis[c] == 0 && cycle(c, &mut vis, &adj))
}
}