summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornekineki <nekineki@nekineki.net>2024-12-20 20:54:10 +0100
committernekineki <nekineki@nekineki.net>2024-12-20 20:54:10 +0100
commit4c8c5406d4d4e0e637e642f7770e011510e09e47 (patch)
tree8e7b86798638884bb931afaf62a7bf804202dc67
parent06e8f9189669b536a9fb4b4c5e82b60552f3015f (diff)
day18
-rw-r--r--2024/day18.rs151
-rw-r--r--2024/in/day18.pzl3450
-rw-r--r--2024/in/day18.ref25
3 files changed, 3626 insertions, 0 deletions
diff --git a/2024/day18.rs b/2024/day18.rs
new file mode 100644
index 0000000..52f8ff1
--- /dev/null
+++ b/2024/day18.rs
@@ -0,0 +1,151 @@
+#![allow(dead_code)]
+#![allow(unused_variables)]
+#![allow(unused_mut)]
+use std::cmp::min;
+use std::collections::HashMap;
+use std::collections::HashSet;
+use std::env;
+use std::fs::File;
+use std::io::Read;
+
+fn dfs(
+ depth: i64,
+ sx: i64,
+ sy: i64,
+ size: i64,
+ m: &Vec<Vec<bool>>,
+ lut: &mut HashMap<(i64, i64), i64>,
+) -> i64 {
+ if sx == size - 1 && sy == size - 1 {
+ return depth;
+ }
+
+ if let Some(val) = lut.get(&(sx, sy)) {
+ if *val < depth {
+ return 99999999999;
+ }
+ }
+ lut.insert((sx, sy), depth);
+
+ let mut s = 99999999999;
+
+ for (dx, dy) in [(1, 0), (-1, 0), (0, 1), (0, -1)] {
+ let mut x = sx + dx;
+ let mut y = sy + dy;
+ if 0 <= x && x < size && 0 <= y && y < size {
+ if m[y as usize][x as usize] {
+ let a = dfs(depth + 1, x, y, size, &m, lut);
+ s = min(s, a);
+ }
+ }
+ }
+
+ return s;
+}
+
+fn bfs(size: i64, m: &Vec<Vec<bool>>) -> i64 {
+ let mut new_pos: HashSet<(i64, i64)> = HashSet::new();
+ let mut all_pos: HashSet<(i64, i64)> = HashSet::new();
+ let mut cur_pos: HashSet<(i64, i64)>;
+
+ new_pos.insert((0, 0));
+
+ all_pos = &all_pos | &new_pos;
+ cur_pos = new_pos.clone();
+ new_pos.clear();
+
+ for depth in 0.. {
+ for (sx, sy) in cur_pos.clone() {
+ for (dx, dy) in [(1, 0), (-1, 0), (0, 1), (0, -1)] {
+ let mut x = sx + dx;
+ let mut y = sy + dy;
+ if sx == size - 1 && sy == size - 1 {
+ return depth;
+ }
+ if 0 <= x && x < size && 0 <= y && y < size {
+ if m[y as usize][x as usize] {
+ if !all_pos.contains(&(x, y)) {
+ new_pos.insert((x, y));
+ }
+ }
+ }
+ }
+ }
+ if new_pos.len() == 0 {
+ return 0;
+ }
+ all_pos = &all_pos | &new_pos;
+ cur_pos = new_pos.clone();
+ new_pos.clear();
+ }
+
+ return 0;
+}
+
+fn print_m(m: &Vec<Vec<bool>>) {
+ for l in m {
+ for c in l {
+ if *c == true {
+ print!(".");
+ } else {
+ print!("#");
+ }
+ }
+ println!();
+ }
+}
+
+fn main() {
+ let args: Vec<String> = env::args().collect();
+ let filename = if args.len() == 1 {
+ "in/".to_owned() + args[0].split('/').last().unwrap() + ".pzl"
+ } else {
+ args[1].clone()
+ };
+ let mut f = File::open(filename).expect("cannot open file");
+ let mut content = String::new();
+ f.read_to_string(&mut content).expect("cannot read file");
+ let lines = content.trim_end().split("\n");
+
+ let mut bytes: Vec<(i64, i64)> = Vec::new();
+ for line in lines {
+ let (a, b) = line.split_once(',').unwrap();
+ bytes.push((a.parse().unwrap(), b.parse().unwrap()));
+ }
+ //println!("{:?}", bytes);
+
+ //let size = 6 + 1;
+ //let mut fall = 12;
+ let size = 70 + 1;
+ let mut fall = 1024;
+
+ let mut m: Vec<Vec<bool>> = vec![vec![true; size]; size];
+ for i in 0..fall {
+ let x = bytes[i].0 as usize;
+ let y = bytes[i].1 as usize;
+ m[y][x] = false;
+ }
+ //print_m(&m);
+
+ let mut lut: HashMap<(i64, i64), i64> = HashMap::new();
+ //let res1 = dfs(0, 0, 0, size as i64, &m, &mut lut);
+ let res1 = bfs(size as i64, &m);
+
+ let mut res2;
+ loop {
+ let x = bytes[fall].0 as usize;
+ let y = bytes[fall].1 as usize;
+ m[y][x] = false;
+ fall += 1;
+ let res = bfs(size as i64, &m);
+ if res == 0 {
+ res2 = format!("{},{}", x, y);
+ break;
+ }
+ }
+
+ println!("res1: {}", res1);
+ println!("res2: {}", res2);
+ assert_eq!(res1, 324);
+ assert_eq!(res2, "46,23");
+}
diff --git a/2024/in/day18.pzl b/2024/in/day18.pzl
new file mode 100644
index 0000000..a15d3de
--- /dev/null
+++ b/2024/in/day18.pzl
@@ -0,0 +1,3450 @@
+69,36
+47,45
+15,15
+27,53
+17,53
+19,7
+57,56
+66,29
+25,13
+58,63
+62,29
+69,66
+44,63
+42,57
+11,3
+5,21
+1,27
+57,49
+57,39
+34,55
+67,59
+17,31
+14,31
+19,1
+57,55
+9,9
+64,47
+65,57
+63,55
+15,27
+10,3
+61,70
+61,47
+3,36
+43,57
+50,51
+26,7
+47,63
+69,41
+9,11
+69,33
+57,46
+35,60
+34,7
+1,35
+6,3
+30,9
+59,51
+24,13
+51,59
+27,57
+11,6
+7,29
+63,32
+32,3
+66,67
+17,11
+9,23
+51,58
+65,27
+33,14
+17,23
+38,5
+63,33
+63,68
+41,63
+31,55
+25,5
+28,61
+44,47
+56,53
+35,5
+65,50
+9,4
+47,39
+12,19
+49,39
+47,68
+54,49
+55,39
+1,6
+41,65
+3,16
+51,42
+11,5
+65,55
+21,7
+37,13
+27,5
+35,65
+55,47
+63,51
+6,23
+54,35
+67,33
+65,43
+63,36
+55,55
+27,21
+33,57
+56,69
+53,46
+19,3
+7,3
+41,8
+11,27
+2,1
+55,65
+45,67
+39,65
+39,9
+53,39
+60,43
+25,7
+3,19
+29,9
+15,8
+41,61
+3,28
+65,69
+60,51
+57,43
+52,63
+47,49
+49,64
+33,55
+10,15
+54,63
+23,18
+46,67
+17,15
+49,55
+16,27
+14,27
+55,56
+69,23
+32,7
+59,66
+13,7
+62,33
+3,31
+53,25
+47,64
+5,17
+57,33
+50,65
+57,61
+26,13
+41,64
+52,61
+50,59
+53,65
+9,17
+33,6
+11,28
+52,57
+69,61
+39,3
+33,9
+62,43
+10,25
+36,13
+64,33
+37,51
+13,8
+31,3
+24,1
+69,31
+65,56
+55,37
+63,28
+61,57
+7,23
+1,3
+65,31
+68,69
+39,2
+36,5
+9,21
+31,61
+63,31
+37,17
+23,3
+23,15
+44,65
+39,7
+45,55
+65,47
+67,50
+67,56
+63,44
+17,13
+30,1
+60,33
+1,11
+3,3
+53,55
+67,24
+2,3
+24,7
+1,9
+40,47
+3,25
+27,56
+4,17
+23,11
+57,36
+19,15
+9,13
+24,5
+7,25
+31,66
+49,59
+65,51
+27,19
+66,39
+32,53
+53,45
+39,63
+38,65
+14,17
+14,19
+57,51
+51,52
+52,37
+69,39
+65,63
+63,54
+63,25
+32,11
+11,1
+35,3
+42,53
+47,69
+11,26
+51,34
+1,5
+59,48
+61,63
+50,37
+70,59
+5,30
+48,35
+67,40
+65,41
+25,15
+63,61
+12,17
+39,59
+55,59
+7,13
+25,8
+69,51
+19,19
+9,7
+10,31
+69,29
+23,9
+51,51
+63,58
+6,17
+23,1
+47,54
+33,1
+60,45
+9,27
+28,55
+5,3
+11,0
+45,52
+34,3
+2,31
+69,54
+22,13
+12,3
+8,7
+55,34
+62,35
+6,15
+39,57
+43,63
+4,23
+21,1
+16,13
+7,15
+23,65
+28,53
+61,56
+65,61
+61,62
+7,26
+5,11
+49,53
+57,65
+59,49
+50,49
+47,34
+53,48
+7,17
+63,64
+41,51
+31,59
+61,61
+69,27
+14,29
+47,65
+13,15
+7,32
+59,33
+61,31
+3,11
+30,53
+47,55
+41,45
+23,58
+13,12
+62,65
+53,67
+51,47
+42,5
+55,63
+58,37
+49,42
+3,7
+51,45
+45,48
+15,19
+3,1
+67,58
+16,21
+59,57
+67,64
+51,43
+64,29
+40,67
+41,67
+7,7
+33,10
+61,27
+20,11
+45,58
+51,68
+57,27
+54,55
+30,15
+41,62
+59,47
+3,27
+42,67
+57,54
+57,45
+45,66
+53,33
+45,49
+13,5
+57,31
+63,67
+53,59
+51,63
+67,65
+64,59
+57,42
+61,59
+7,27
+25,3
+53,54
+41,15
+28,15
+25,1
+56,51
+53,53
+69,65
+63,65
+69,68
+66,69
+43,68
+15,1
+27,59
+47,57
+53,47
+30,61
+11,11
+47,59
+61,29
+13,26
+30,11
+45,43
+60,37
+68,27
+11,15
+3,20
+39,5
+53,44
+55,41
+26,57
+11,21
+57,57
+66,65
+13,10
+23,19
+20,7
+13,22
+63,30
+41,60
+1,30
+28,7
+23,13
+29,56
+13,21
+68,43
+9,22
+65,52
+51,46
+42,65
+61,65
+49,67
+4,11
+62,53
+10,5
+60,69
+57,69
+69,43
+67,38
+54,59
+40,61
+32,61
+34,61
+43,67
+53,43
+44,57
+58,59
+21,2
+29,57
+7,1
+29,61
+5,27
+2,11
+47,51
+8,19
+13,1
+67,61
+63,53
+1,29
+68,61
+27,15
+28,1
+61,58
+15,5
+9,12
+34,11
+54,61
+61,60
+11,24
+4,5
+17,41
+31,6
+33,63
+39,11
+63,46
+59,30
+47,50
+9,29
+57,35
+5,20
+63,57
+23,5
+37,55
+62,57
+1,25
+22,3
+55,42
+15,17
+5,25
+19,6
+49,57
+35,53
+56,61
+38,47
+49,63
+63,62
+37,15
+17,14
+31,60
+12,11
+5,33
+40,57
+59,28
+14,15
+33,13
+7,24
+58,45
+70,29
+19,5
+65,49
+57,63
+4,1
+59,64
+15,10
+67,41
+37,8
+22,23
+35,59
+57,29
+49,38
+28,13
+65,59
+7,19
+52,67
+11,25
+60,57
+59,37
+3,15
+46,63
+67,53
+38,13
+59,55
+13,13
+58,51
+13,11
+1,20
+38,61
+43,55
+3,21
+67,42
+65,22
+68,29
+53,51
+11,9
+5,15
+15,3
+21,12
+55,53
+29,51
+55,66
+59,67
+9,18
+63,49
+59,35
+5,5
+5,28
+17,19
+61,40
+37,60
+5,32
+47,67
+69,46
+48,41
+53,31
+11,17
+67,67
+5,22
+17,16
+13,25
+11,29
+45,63
+39,64
+65,70
+53,63
+22,15
+13,19
+55,45
+61,39
+39,58
+4,25
+27,55
+53,61
+59,59
+55,51
+53,60
+31,14
+67,43
+13,14
+63,21
+31,5
+2,35
+13,2
+27,9
+4,33
+69,49
+21,4
+35,63
+49,31
+59,34
+27,13
+5,31
+49,66
+21,10
+0,15
+2,7
+33,4
+54,57
+23,0
+67,63
+67,57
+23,20
+45,60
+55,35
+55,69
+39,8
+69,58
+18,5
+11,23
+21,13
+19,2
+27,2
+2,25
+61,53
+11,20
+69,62
+8,13
+5,26
+15,21
+35,7
+35,8
+55,31
+67,45
+53,57
+57,60
+5,18
+3,29
+0,29
+6,29
+65,33
+27,10
+5,4
+25,4
+55,43
+1,31
+37,9
+8,29
+27,1
+17,4
+11,22
+61,36
+63,50
+69,47
+11,7
+9,1
+45,7
+15,4
+57,38
+49,56
+69,53
+2,27
+69,34
+19,14
+5,12
+25,61
+67,69
+37,56
+57,30
+35,64
+41,57
+1,33
+65,34
+2,9
+61,49
+10,11
+67,35
+59,39
+70,51
+21,17
+64,55
+3,37
+17,18
+63,29
+61,55
+48,55
+51,57
+49,65
+60,25
+65,29
+53,40
+64,67
+0,11
+60,49
+19,4
+60,29
+47,31
+68,31
+16,1
+23,10
+16,9
+61,67
+7,10
+21,5
+1,4
+66,57
+1,41
+69,45
+28,3
+4,9
+69,57
+69,59
+7,2
+39,1
+39,61
+50,63
+57,44
+9,28
+3,13
+55,40
+59,61
+45,51
+10,9
+67,36
+61,35
+65,65
+45,62
+33,18
+26,11
+47,61
+43,61
+57,67
+37,57
+57,47
+31,7
+48,67
+5,13
+67,34
+59,65
+67,44
+55,36
+64,25
+5,6
+9,31
+35,13
+29,16
+42,59
+63,27
+66,53
+25,57
+52,39
+49,49
+60,53
+0,1
+65,67
+69,40
+7,11
+19,10
+35,1
+5,29
+35,61
+22,5
+31,57
+6,39
+48,47
+31,58
+15,30
+59,25
+27,3
+51,41
+25,11
+67,29
+64,63
+8,5
+37,61
+5,34
+13,9
+67,46
+63,47
+43,60
+21,56
+57,66
+5,9
+61,33
+37,52
+7,5
+29,12
+51,44
+69,48
+9,25
+66,61
+2,17
+31,51
+67,37
+54,65
+69,35
+53,37
+21,9
+33,51
+64,37
+63,59
+38,57
+47,41
+33,58
+46,47
+37,11
+51,55
+55,44
+32,55
+29,13
+69,37
+56,33
+27,7
+3,5
+56,49
+8,31
+26,3
+39,54
+49,70
+33,3
+9,19
+33,11
+7,0
+3,33
+23,7
+37,66
+29,11
+54,51
+54,45
+40,53
+7,34
+41,5
+29,1
+6,7
+65,26
+29,7
+4,7
+1,26
+15,25
+27,6
+1,32
+6,9
+66,37
+3,34
+49,52
+68,23
+15,11
+17,21
+59,45
+15,16
+59,68
+3,14
+47,53
+59,54
+60,31
+37,62
+35,0
+63,69
+31,9
+11,8
+52,51
+33,0
+15,12
+42,55
+53,42
+64,43
+61,69
+14,5
+47,62
+19,13
+58,55
+55,61
+17,17
+17,20
+1,7
+33,5
+41,53
+69,55
+17,7
+55,33
+63,48
+48,61
+35,9
+12,5
+60,61
+35,12
+43,6
+64,39
+12,33
+45,59
+31,1
+53,35
+34,57
+49,58
+49,41
+37,6
+35,57
+36,63
+37,59
+59,69
+13,27
+36,57
+69,63
+37,7
+45,47
+61,37
+69,67
+9,5
+65,35
+51,48
+68,53
+56,63
+1,13
+48,49
+39,55
+45,61
+51,36
+45,65
+68,65
+19,11
+49,61
+53,49
+28,9
+39,4
+55,49
+5,19
+51,61
+36,11
+51,49
+7,21
+69,56
+67,51
+5,23
+57,53
+57,59
+33,53
+61,46
+7,9
+62,67
+11,37
+5,1
+16,19
+8,23
+29,5
+43,43
+10,19
+29,3
+12,13
+35,55
+18,1
+57,41
+57,58
+35,2
+58,49
+9,16
+21,8
+63,63
+47,47
+63,41
+27,11
+67,32
+53,34
+51,53
+70,41
+33,7
+15,7
+17,1
+17,5
+22,7
+69,69
+67,47
+63,52
+7,20
+6,13
+3,38
+66,47
+15,6
+33,61
+21,3
+67,55
+61,66
+9,3
+43,59
+5,7
+8,9
+56,47
+57,40
+30,55
+41,59
+46,57
+63,45
+31,8
+67,60
+32,13
+39,10
+9,2
+30,5
+8,15
+24,11
+3,9
+25,9
+37,5
+53,29
+69,38
+37,54
+29,4
+29,47
+13,17
+36,3
+45,54
+65,53
+65,37
+59,62
+70,25
+38,51
+3,17
+53,41
+15,13
+66,31
+1,1
+14,1
+64,61
+58,33
+51,35
+62,41
+9,26
+50,61
+29,55
+33,59
+55,38
+31,11
+63,35
+4,13
+64,41
+27,23
+49,43
+49,40
+43,65
+44,55
+37,10
+41,6
+17,8
+45,21
+10,61
+5,65
+47,35
+15,59
+14,33
+20,35
+2,45
+11,49
+1,43
+1,51
+27,39
+24,23
+29,33
+35,42
+13,50
+45,11
+11,32
+48,11
+25,41
+6,47
+33,17
+41,31
+66,1
+21,40
+69,8
+7,42
+50,9
+57,18
+43,1
+37,44
+34,67
+13,69
+28,49
+15,39
+11,61
+48,9
+35,67
+42,17
+39,24
+38,69
+26,61
+9,45
+25,47
+69,21
+45,3
+19,28
+43,34
+51,3
+26,65
+39,15
+69,19
+43,45
+26,19
+5,66
+49,6
+5,43
+35,52
+59,15
+34,19
+32,49
+45,35
+21,55
+10,41
+33,22
+12,57
+25,49
+41,33
+3,23
+63,8
+13,52
+23,22
+27,44
+13,47
+25,29
+32,39
+39,37
+41,47
+36,19
+37,31
+31,22
+27,65
+19,45
+57,12
+39,34
+51,16
+54,3
+47,23
+33,36
+52,9
+5,55
+55,13
+15,33
+14,63
+25,58
+14,69
+5,42
+7,48
+3,43
+1,65
+21,37
+42,39
+49,16
+11,31
+38,39
+57,22
+63,7
+21,22
+37,27
+17,46
+17,65
+40,31
+52,13
+47,17
+17,43
+22,41
+41,27
+67,23
+69,0
+61,51
+9,56
+43,32
+37,63
+31,43
+44,69
+43,41
+23,27
+17,36
+3,59
+51,1
+2,63
+44,39
+17,35
+63,23
+1,53
+19,63
+15,52
+37,41
+35,51
+21,36
+39,17
+9,51
+55,23
+23,57
+65,11
+49,26
+1,40
+60,11
+56,19
+15,31
+49,23
+44,49
+36,45
+9,40
+5,35
+11,44
+2,49
+47,13
+3,45
+41,49
+3,55
+53,6
+51,17
+7,45
+25,59
+1,47
+45,33
+15,66
+56,9
+67,49
+0,21
+53,3
+43,51
+8,69
+45,15
+1,69
+66,7
+29,26
+1,67
+66,49
+27,22
+33,38
+45,22
+41,38
+53,15
+29,58
+1,23
+23,44
+33,43
+41,23
+16,65
+36,39
+20,39
+16,33
+49,32
+61,11
+55,24
+17,49
+15,44
+63,13
+1,17
+57,28
+39,40
+7,63
+13,68
+13,24
+21,15
+27,61
+45,19
+47,25
+31,63
+7,69
+41,35
+19,42
+11,66
+67,19
+14,57
+4,55
+0,37
+17,25
+17,47
+23,34
+47,27
+29,38
+7,37
+21,29
+24,17
+50,13
+45,45
+47,11
+26,25
+51,24
+27,31
+29,65
+59,31
+22,67
+22,53
+51,37
+39,31
+60,1
+15,42
+67,1
+43,16
+59,2
+19,30
+3,69
+55,21
+35,23
+11,53
+17,48
+10,69
+61,41
+7,55
+45,2
+43,31
+65,6
+65,17
+27,69
+46,27
+51,39
+59,11
+8,65
+3,47
+67,10
+29,29
+19,57
+14,37
+60,5
+1,66
+40,21
+21,27
+55,27
+38,23
+48,5
+49,1
+27,51
+29,30
+39,53
+17,55
+20,31
+67,7
+65,25
+61,7
+42,29
+9,46
+38,37
+53,20
+53,66
+45,29
+23,17
+26,69
+53,12
+51,30
+33,25
+23,37
+9,43
+16,25
+16,57
+25,65
+58,41
+29,20
+19,47
+18,43
+57,20
+23,25
+55,29
+29,23
+47,3
+11,34
+33,39
+28,65
+40,39
+29,25
+33,30
+40,17
+19,69
+31,69
+27,35
+3,41
+43,69
+67,4
+3,67
+23,61
+7,61
+43,3
+47,29
+27,26
+38,29
+23,39
+51,4
+48,53
+14,23
+65,13
+16,59
+66,23
+33,23
+47,37
+5,47
+67,26
+48,23
+31,36
+63,19
+17,68
+14,59
+56,5
+41,70
+42,15
+14,55
+35,54
+10,51
+11,51
+49,15
+9,15
+21,33
+69,22
+25,37
+7,47
+17,29
+40,43
+65,3
+51,10
+65,39
+59,29
+13,37
+45,18
+14,67
+65,18
+49,25
+41,69
+21,44
+51,67
+13,31
+3,40
+29,32
+29,22
+51,29
+28,63
+35,29
+57,19
+23,45
+59,7
+27,36
+39,43
+59,63
+33,31
+69,15
+19,17
+10,53
+3,57
+39,42
+21,57
+7,44
+51,23
+25,63
+9,34
+7,52
+21,67
+12,41
+22,27
+9,39
+37,23
+33,69
+25,54
+2,53
+29,35
+15,23
+18,69
+63,24
+18,39
+33,24
+43,19
+3,53
+61,12
+17,33
+43,35
+11,36
+61,18
+43,33
+47,21
+68,19
+32,19
+1,14
+24,45
+19,35
+63,20
+48,37
+27,33
+31,31
+53,28
+8,63
+27,43
+15,47
+53,7
+11,69
+5,37
+35,18
+9,36
+51,65
+65,19
+50,19
+43,11
+31,15
+47,1
+69,5
+31,17
+63,10
+61,5
+25,35
+8,53
+28,69
+54,69
+17,61
+37,37
+29,28
+3,48
+53,21
+54,15
+65,9
+46,25
+37,1
+13,60
+59,5
+12,43
+41,43
+61,0
+41,13
+51,31
+45,31
+45,10
+1,49
+11,65
+46,43
+35,17
+41,4
+57,13
+21,58
+27,67
+31,47
+35,21
+36,31
+19,62
+20,23
+19,34
+17,27
+9,53
+69,6
+41,37
+19,64
+33,34
+3,65
+43,9
+68,3
+53,23
+13,54
+41,19
+13,51
+7,53
+2,23
+12,47
+10,43
+40,49
+62,13
+29,41
+25,21
+33,33
+23,35
+25,66
+46,7
+5,41
+65,20
+36,51
+3,35
+28,47
+19,53
+67,21
+30,51
+46,33
+39,21
+19,49
+25,34
+53,11
+9,57
+8,55
+28,41
+10,55
+55,67
+66,45
+20,67
+13,64
+43,5
+31,32
+57,1
+49,20
+15,53
+54,5
+57,15
+67,15
+24,69
+37,30
+31,33
+27,63
+39,51
+37,25
+58,11
+18,23
+17,39
+9,59
+37,49
+42,47
+26,47
+23,42
+37,68
+14,41
+5,69
+55,57
+51,22
+27,34
+27,38
+13,41
+6,37
+49,17
+43,50
+51,33
+43,49
+34,43
+11,67
+39,41
+44,11
+63,22
+1,39
+7,51
+9,35
+4,43
+67,25
+43,30
+31,49
+53,13
+53,1
+39,13
+7,35
+51,7
+21,64
+11,59
+53,17
+55,8
+45,14
+2,51
+41,2
+69,11
+51,13
+30,31
+33,29
+55,32
+59,23
+17,28
+57,2
+55,14
+19,16
+15,46
+24,67
+69,13
+13,33
+3,63
+48,45
+63,9
+45,37
+45,4
+25,45
+22,65
+59,8
+27,46
+31,45
+31,53
+11,13
+12,51
+23,30
+59,53
+39,16
+50,69
+58,9
+33,47
+25,40
+67,11
+44,27
+42,25
+11,39
+65,16
+60,39
+13,65
+25,39
+24,25
+1,46
+18,57
+37,53
+17,69
+64,13
+23,62
+43,7
+21,49
+48,29
+51,11
+21,59
+43,26
+20,49
+61,15
+49,21
+3,61
+13,23
+17,26
+18,49
+9,63
+11,45
+11,43
+29,53
+45,25
+23,67
+12,67
+42,21
+46,15
+37,36
+47,9
+4,39
+29,69
+57,25
+1,19
+55,1
+47,40
+26,49
+19,61
+61,9
+66,17
+41,39
+14,49
+13,45
+15,34
+49,7
+23,51
+43,47
+17,37
+8,43
+6,53
+30,17
+27,37
+32,69
+27,17
+6,63
+25,42
+22,63
+3,22
+36,37
+5,53
+24,47
+63,43
+13,35
+57,3
+16,69
+37,21
+5,60
+55,25
+5,39
+49,11
+43,14
+33,35
+37,69
+15,55
+41,24
+43,52
+15,29
+35,35
+56,23
+18,11
+45,36
+35,25
+32,21
+7,31
+48,1
+48,21
+11,48
+70,3
+34,33
+15,41
+39,29
+55,7
+35,11
+59,1
+36,15
+62,9
+45,30
+21,31
+37,45
+31,27
+15,61
+20,19
+65,15
+57,4
+35,19
+19,60
+20,45
+19,26
+65,7
+25,25
+0,51
+25,31
+41,41
+9,38
+57,7
+21,23
+32,25
+41,21
+45,1
+23,48
+25,33
+50,29
+34,29
+39,28
+31,35
+17,63
+41,42
+11,62
+55,9
+29,39
+5,51
+25,23
+49,18
+50,45
+33,15
+47,43
+37,48
+26,31
+5,62
+11,55
+9,55
+65,23
+30,25
+26,63
+20,17
+44,5
+61,3
+59,3
+67,2
+29,49
+18,35
+35,43
+33,37
+18,47
+63,37
+55,12
+13,29
+51,12
+24,35
+44,35
+51,15
+33,64
+37,19
+39,26
+49,47
+29,19
+12,55
+23,29
+42,45
+31,37
+53,69
+28,19
+59,13
+57,23
+1,37
+49,14
+65,8
+55,15
+9,49
+19,18
+66,13
+39,33
+67,39
+30,47
+65,14
+24,55
+9,69
+33,26
+47,16
+13,43
+36,33
+20,59
+53,30
+69,25
+45,41
+36,67
+69,7
+5,64
+59,17
+23,46
+39,22
+32,67
+17,45
+41,17
+35,70
+54,9
+35,39
+30,35
+25,27
+31,39
+19,23
+1,58
+45,9
+13,53
+29,24
+63,5
+7,39
+52,5
+6,59
+63,1
+57,11
+55,3
+60,21
+57,6
+1,21
+59,20
+51,69
+49,2
+6,57
+37,34
+19,39
+19,66
+23,33
+36,21
+49,44
+49,9
+21,65
+45,46
+53,22
+19,20
+7,67
+14,45
+31,28
+17,54
+37,65
+13,39
+20,55
+43,44
+20,69
+34,47
+30,63
+32,51
+52,1
+13,38
+16,23
+11,63
+39,46
+22,49
+35,66
+46,39
+2,43
+15,69
+61,24
+31,34
+47,15
+41,12
+31,46
+26,39
+45,53
+4,67
+47,19
+19,54
+65,1
+27,30
+45,27
+50,3
+70,19
+59,19
+41,29
+33,27
+53,19
+46,51
+45,17
+37,39
+53,2
+2,65
+31,23
+1,61
+49,3
+57,64
+35,41
+33,65
+32,41
+61,14
+19,41
+34,45
+11,33
+28,67
+15,43
+43,27
+17,56
+51,19
+23,21
+57,17
+21,43
+22,69
+7,70
+43,8
+33,49
+63,16
+23,41
+26,43
+19,38
+24,15
+67,20
+45,12
+13,62
+21,25
+15,45
+21,41
+17,3
+3,62
+68,7
+38,17
+32,29
+36,23
+43,17
+39,27
+59,21
+43,2
+19,55
+62,3
+17,59
+45,69
+7,33
+8,59
+19,21
+51,5
+41,9
+47,30
+21,52
+15,65
+30,67
+47,4
+45,23
+27,47
+19,29
+13,57
+45,20
+21,46
+36,25
+19,31
+12,29
+4,51
+9,64
+35,28
+54,27
+28,35
+63,3
+56,25
+45,28
+31,67
+9,50
+29,40
+27,49
+6,67
+5,45
+41,7
+24,27
+26,23
+6,55
+41,44
+67,17
+63,39
+29,67
+39,69
+31,42
+39,35
+15,49
+54,17
+25,69
+61,19
+15,67
+53,27
+17,9
+9,48
+53,9
+60,41
+21,60
+64,5
+63,17
+15,37
+27,28
+61,6
+47,22
+7,65
+6,51
+45,32
+59,18
+55,17
+23,23
+22,33
+31,41
+43,36
+43,15
+43,37
+65,5
+23,47
+24,51
+16,49
+34,23
+46,19
+13,55
+5,68
+34,39
+33,67
+21,35
+9,33
+39,67
+39,32
+39,50
+20,51
+17,67
+31,19
+19,27
+30,69
+24,57
+11,58
+35,15
+39,47
+30,39
+5,36
+21,21
+15,9
+35,16
+57,37
+52,25
+5,63
+52,15
+66,11
+37,42
+29,15
+40,35
+65,21
+41,56
+64,11
+29,17
+39,25
+13,63
+13,59
+27,41
+11,41
+21,39
+21,19
+34,51
+43,29
+1,56
+49,35
+19,67
+7,43
+25,20
+29,59
+47,5
+4,47
+29,21
+55,0
+18,51
+49,13
+39,39
+10,65
+31,44
+43,23
+21,53
+25,55
+29,43
+47,18
+33,19
+27,60
+6,45
+68,13
+57,26
+45,24
+9,67
+13,61
+58,5
+49,69
+16,37
+57,21
+21,47
+53,32
+22,25
+1,60
+19,44
+35,33
+16,53
+18,31
+65,45
+59,9
+53,18
+59,16
+53,5
+57,9
+69,12
+17,64
+5,49
+68,17
+61,43
+38,1
+21,69
+16,61
+45,13
+43,21
+25,43
+13,3
+49,37
+41,36
+24,63
+8,39
+59,22
+44,41
+59,41
+32,45
+40,11
+35,37
+37,33
+59,27
+13,36
+67,5
+27,29
+45,5
+36,27
+25,36
+61,26
+67,3
+61,25
+5,67
+23,49
+16,51
+58,15
+51,32
+9,65
+51,27
+41,1
+43,13
+69,9
+22,51
+8,67
+41,3
+39,49
+39,45
+26,15
+25,17
+0,65
+5,59
+1,15
+20,27
+49,51
+35,31
+2,69
+19,25
+24,31
+18,61
+62,5
+1,45
+67,31
+15,51
+62,21
+37,47
+39,19
+49,27
+54,25
+47,58
+27,25
+33,21
+41,32
+35,36
+1,68
+44,9
+61,1
+17,62
+15,57
+63,15
+32,63
+11,19
+23,43
+23,59
+39,23
+55,5
+50,27
+4,57
+67,27
+63,11
+21,63
+38,19
+19,51
+16,43
+58,25
+61,21
+63,18
+26,51
+27,32
+43,18
+51,21
+63,2
+8,61
+52,27
+7,49
+62,51
+46,1
+23,31
+13,49
+31,13
+37,43
+45,57
+37,3
+41,11
+11,35
+70,15
+29,27
+9,58
+22,29
+59,43
+51,9
+10,37
+34,15
+50,7
+46,11
+44,21
+45,42
+37,26
+22,17
+23,69
+29,18
+48,13
+27,27
+61,17
+55,19
+11,46
+49,24
+67,9
+32,47
+7,57
+35,45
+37,67
+5,57
+56,29
+19,33
+40,19
+51,25
+57,5
+42,23
+2,55
+43,25
+13,67
+31,21
+61,13
+17,32
+31,65
+3,39
+45,39
+55,11
+17,57
+41,28
+35,49
+9,37
+19,9
+35,47
+21,61
+65,4
+69,10
+29,50
+46,37
+29,42
+25,51
+49,33
+19,24
+60,9
+26,53
+33,45
+45,44
+49,5
+69,1
+3,60
+67,13
+38,31
+1,57
+31,25
+9,61
+23,63
+21,51
+38,45
+25,28
+69,3
+3,49
+9,41
+19,37
+1,62
+4,53
+49,19
+17,51
+36,49
+29,63
+1,63
+11,57
+16,39
+62,25
+68,49
+18,41
+56,15
+1,55
+21,45
+33,32
+19,43
+41,52
+47,6
+23,53
+1,42
+49,29
+24,39
+69,17
+37,29
+14,39
+11,60
+39,14
+30,65
+41,68
+48,31
+25,67
+68,15
+5,58
+26,17
+35,69
+21,32
+59,14
+41,25
+25,19
+29,45
+15,63
+37,35
+29,37
+1,59
+6,41
+22,37
+33,62
+48,27
+64,3
+47,7
+55,10
+25,53
+5,50
+19,65
+33,41
+29,31
+27,45
+21,11
+7,59
+19,59
+47,33
+1,38
+11,47
+61,23
+4,45
+47,8
+35,27
+35,40
+43,53
+9,47
+40,1
+22,55
+61,45
+42,11
+54,21
+31,29
+25,50
+56,3
+12,63
+52,55
+57,68
+12,39
+5,61
+7,41
+52,19
+34,49
+23,60
+37,20
+3,51
+49,45
+23,55
+8,47
+61,16
+15,35
+41,55
+29,44
+43,0
+43,39
+34,66
+0,61
+1,34
+38,64
+47,44
+63,42
+12,21
+39,56
+19,46
+54,19
+32,64
+15,62
+62,23
+50,55
+0,68
+52,69
+58,23
+38,26
+38,70
+70,47
+30,46
+11,56
+52,26
+1,22
+36,29
+50,70
+48,60
+41,18
+6,42
+34,32
+66,42
+34,20
+50,22
+48,54
+2,18
+65,42
+22,59
+26,70
+60,42
+36,22
+18,22
+0,69
+12,7
+32,2
+30,30
+66,60
+16,30
+54,41
+30,64
+6,60
+48,39
+40,38
+33,68
+70,49
+12,31
+46,52
+62,60
+53,68
+54,56
+52,12
+34,37
+29,46
+44,62
+12,30
+33,66
+28,38
+5,52
+6,58
+10,4
+12,58
+5,46
+25,44
+9,44
+34,12
+4,41
+22,62
+11,52
+64,42
+58,67
+8,12
+69,50
+28,43
+56,26
+20,24
+24,36
+68,63
+14,16
+6,32
+58,20
+46,41
+34,41
+54,52
+44,43
+30,19
+44,16
+8,18
+25,32
+21,30
+21,48
+6,46
+34,68
+4,56
+17,34
+50,26
+23,32
+32,20
+4,31
+47,56
+49,68
+25,18
+7,12
+34,0
+36,50
+18,45
+29,54
+3,56
+38,60
+19,56
+42,8
+0,55
+20,54
+16,66
+38,11
+48,43
+20,10
+3,46
+14,32
+42,64
+30,24
+18,6
+42,10
+31,52
+13,70
+23,52
+20,15
+12,8
+17,40
+4,70
+15,24
+19,52
+66,51
+38,25
+56,16
+57,32
+24,0
+36,70
+43,62
+52,17
+28,58
+38,30
+38,12
+31,26
+43,42
+13,58
+22,14
+60,68
+10,54
+34,48
+21,66
+56,59
+0,12
+34,54
+36,24
+28,59
+14,52
+53,56
+2,32
+68,64
+22,61
+6,56
+24,66
+10,47
+34,22
+15,32
+59,70
+32,27
+4,49
+20,30
+31,40
+7,46
+66,70
+9,24
+10,56
+42,7
+14,22
+57,52
+43,46
+39,20
+30,34
+42,58
+0,64
+33,20
+66,59
+42,35
+20,14
+22,20
+38,50
+70,48
+12,15
+30,58
+47,66
+14,21
+52,52
+32,34
+15,56
+39,38
+29,0
+49,60
+62,44
+26,34
+32,14
+48,46
+35,14
+28,44
+15,48
+9,32
+22,21
+10,58
+14,8
+49,8
+3,6
+26,44
+44,12
+24,70
+62,70
+46,58
+4,28
+12,50
+8,16
+7,30
+38,56
+63,60
+7,60
+0,35
+54,44
+29,36
+27,42
+21,14
+0,52
+56,18
+56,31
+62,32
+6,54
+30,49
+62,31
+28,50
+2,39
+28,39
+18,63
+38,44
+20,40
+59,40
+36,58
+56,66
+38,36
+55,22
+12,10
+31,16
+34,17
+0,28
+40,2
+68,66
+62,4
+34,40
+37,14
+22,31
+16,67
+52,16
+44,36
+20,50
+54,28
+14,20
+70,34
+65,68
+52,14
+63,4
+0,32
+22,1
+38,15
+18,56
+46,38
+35,30
+23,28
+21,18
+60,27
+58,61
+34,64
+26,56
+56,65
+4,52
+14,18
+22,57
+4,10
+10,39
+46,54
+10,46
+8,26
+15,54
+4,3
+12,52
+16,44
+50,62
+32,52
+5,40
+34,16
+48,66
+21,24
+2,50
+22,38
+8,45
+56,52
+44,14
+30,43
+38,22
+29,14
+30,18
+32,1
+10,40
+14,14
+38,40
+55,62
+32,4
+53,4
+46,59
+44,64
+36,16
+12,18
+35,38
+24,54
+40,54
+33,54
+66,64
+44,13
+40,58
+30,21
+40,6
+28,22
+16,31
+64,56
+28,29
+24,53
+41,40
+12,34
+54,14
+55,4
+14,60
+60,58
+22,52
+14,11
+16,26
+20,70
+65,66
+3,54
+48,70
+2,52
+2,48
+55,52
+8,46
+20,36
+49,50
+16,2
+41,54
+26,62
+60,60
+34,46
+14,35
+70,50
+41,58
+54,66
+2,26
+20,65
+36,54
+16,18
+24,68
+48,59
+16,5
+62,30
+40,66
+26,2
+58,69
+42,44
+4,35
+44,20
+29,68
+16,63
+22,34
+58,56
+10,21
+45,38
+50,56
+50,54
+66,56
+38,62
+23,66
+10,32
+31,30
+28,34
+10,50
+14,54
+36,42
+64,68
+32,62
+16,40
+42,41
+32,33
+36,66
+20,46
+40,14
+24,38
+38,54
+5,10
+57,16
+64,4
+62,24
+58,58
+55,58
+16,55
+35,34
+17,66
+34,69
+10,57
+5,70
+16,28
+3,52
+46,62
+49,54
+57,62
+30,70
+39,30
+36,60
+65,60
+30,54
+50,8
+9,66
+22,48
+0,47
+19,48
+33,70
+0,17
+38,33
+12,68
+4,21
+31,4
+32,46
+61,44
+18,21
+48,6
+42,31
+4,27
+0,18
+30,20
+22,58
+38,7
+68,62
+58,44
+32,43
+12,66
+33,12
+48,58
+64,28
+0,16
+53,52
+31,2
+8,64
+51,2
+70,54
+16,16
+56,67
+20,60
+34,21
+50,15
+9,42
+32,65
+40,59
+39,68
+12,22
+27,70
+38,14
+30,23
+53,24
+27,68
+54,53
+59,26
+24,33
+58,29
+6,50
+70,33
+28,2
+53,70
+56,27
+18,40
+41,50
+8,54
+8,35
+50,53
+28,46
+3,26
+15,64
+8,68
+16,15
+26,58
+17,38
+0,60
+64,40
+46,17
+55,30
+19,40
+61,28
+33,52
+11,68
+38,10
+10,18
+39,52
+52,21
+16,64
+22,46
+3,12
+43,66
+27,66
+54,18
+6,62
+9,68
+60,26
+0,31
+63,66
+6,28
+14,47
+60,54
+52,2
+55,20
+12,64
+18,3
+6,38
+2,56
+10,14
+39,6
+46,23
+28,28
+54,32
+16,24
+31,64
+55,50
+6,30
+44,6
+30,10
+48,56
+36,8
+40,10
+7,38
+42,61
+42,70
+4,22
+46,4
+10,60
+32,58
+35,68
+20,28
+42,9
+25,2
+8,56
+31,24
+25,10
+34,18
+2,21
+46,30
+62,10
+24,21
+40,34
+60,59
+44,19
+10,7
+50,24
+62,12
+64,14
+34,70
+69,16
+23,12
+60,48
+58,26
+34,34
+4,30
+36,44
+18,67
+64,49
+18,4
+54,39
+16,54
+13,42
+0,49
+30,56
+33,44
+39,62
+25,38
+58,24
+62,47
+17,24
+57,70
+54,70
+31,0
+6,0
+52,70
+32,68
+54,2
+4,6
+58,42
+58,70
+20,0
+2,22
+70,45
+22,45
+36,64
+4,44
+7,64
+46,66
+6,61
+62,38
+54,60
+0,24
+30,14
+0,23
+52,62
+20,66
+69,44
+49,28
+19,32
+12,20
+40,9
+42,26
+52,64
+22,30
+38,4
+24,26
+54,26
+41,34
+6,70
+4,2
+36,6
+27,16
+30,38
+58,31
+50,10
+50,18
+23,24
+58,3
+37,16
+23,64
+52,7
+25,24
+31,68
+42,54
+27,64
+40,46
+13,32
+30,57
+6,6
+42,46
+65,44
+10,22
+58,12
+36,18
+36,46
+7,40
+14,25
+10,44
+66,34
+23,8
+69,18
+48,38
+50,11
+14,0
+34,36
+56,38
+14,64
+55,28
+60,13
+62,63
+17,6
+4,66
+42,43
+37,46
+70,6
+61,34
+24,61
+21,42
+29,60
+16,52
+56,70
+32,0
+32,16
+56,7
+43,56
+68,21
+46,18
+30,16
+54,37
+4,61
+21,70
+34,52
+30,4
+52,43
+58,68
+50,23
+2,57
+36,17
+10,20
+51,66
+26,36
+16,34
+48,8
+62,16
+58,7
+52,31
+45,68
+4,24
+26,1
+50,20
+33,8
+25,6
+11,70
+18,2
+66,27
+8,0
+47,12
+46,44
+24,43
+12,26
+29,10
+27,0
+15,28
+28,51
+46,20
+13,6
+5,44
+9,54
+6,35
+49,4
+53,62
+50,66
+10,42
+68,68
+64,1
+66,40
+68,36
+48,32
+14,12
+13,30
+70,11
+46,21
+62,59
+70,39
+28,14
+6,65
+35,6
+48,25
+9,10
+34,27
+42,13
+14,4
+32,8
+58,4
+17,42
+8,22
+53,14
+52,58
+70,60
+30,60
+16,3
+36,62
+20,21
+44,26
+14,51
+18,14
+58,32
+24,4
+51,26
+36,32
+55,26
+53,38
+10,64
+4,12
+70,18
+61,68
+20,64
+50,30
+6,66
+2,61
+29,2
+47,42
+20,57
+10,48
+44,33
+0,8
+44,23
+8,49
+4,64
+32,15
+48,4
+1,8
+53,50
+16,22
+3,58
+15,38
+21,16
+56,46
+8,3
+13,28
+40,16
+50,35
+62,2
+23,50
+46,46
+12,1
+18,29
+51,20
+0,42
+15,70
+11,42
+0,44
+22,24
+32,17
+60,40
+32,36
+42,14
+12,2
+18,64
+56,64
+24,50
+40,8
+60,6
+5,2
+26,59
+30,42
+40,52
+61,30
+12,6
+11,16
+0,34
+26,67
+62,28
+6,27
+58,53
+35,26
+56,10
+23,70
+28,10
+0,50
+58,40
+51,38
+56,41
+44,56
+50,48
+48,50
+64,27
+17,44
+17,58
+68,11
+52,53
+53,8
+14,42
+42,33
+0,53
+36,55
+58,48
+52,4
+40,41
+9,6
+39,48
+23,6
+68,0
+30,28
+15,0
+7,58
+66,41
+44,42
+22,54
+67,70
+44,48
+50,31
+28,20
+0,4
+7,28
+54,20
+64,24
+0,54
+46,22
+2,41
+18,66
+64,70
+68,37
+58,30
+62,18
+44,59
+35,20
+32,42
+24,41
+12,62
+1,70
+62,6
+26,16
+48,28
+2,24
+64,9
+18,27
+39,66
+50,12
+11,64
+64,15
+14,65
+44,70
+15,40
+12,54
+51,18
+58,1
+37,28
+41,0
+62,68
+2,40
+70,0
+54,64
+52,34
+68,55
+10,66
+22,10
+49,48
+18,50
+38,48
+52,60
+58,66
+32,12
+11,12
+2,13
+38,34
+56,39
+30,26
+64,36
+52,23
+52,59
+15,36
+45,56
+66,5
+69,32
+18,33
+56,1
+32,32
+13,34
+62,56
+0,13
+70,22
+38,49
+52,45
+31,70
+14,6
+18,38
+1,48
+62,8
+56,42
+20,2
+65,10
+16,68
+60,4
+56,12
+40,20
+34,59
+8,24
+59,44
+36,43
+27,62
+6,49
+60,47
+50,36
+29,52
+28,12
+15,58
+34,6
+59,0
+61,64
+54,29
+53,10
+40,65
+39,60
+47,10
+14,3
+48,65
+22,0
+13,16
+64,66
+68,22
+21,62
+44,52
+62,46
+44,40
+59,52
+64,45
+68,47
+10,10
+20,18
+26,28
+26,38
+42,37
+40,70
diff --git a/2024/in/day18.ref b/2024/in/day18.ref
new file mode 100644
index 0000000..79c8583
--- /dev/null
+++ b/2024/in/day18.ref
@@ -0,0 +1,25 @@
+5,4
+4,2
+4,5
+3,0
+2,1
+6,3
+2,4
+1,5
+0,6
+3,3
+2,6
+5,1
+1,2
+5,5
+2,5
+6,5
+1,4
+0,4
+6,4
+1,1
+6,1
+1,0
+0,5
+1,6
+2,0