Day 4 Checkin
+ First day with a multiline input, added new infrastructure for that + Will need some refinement in the futuremain
parent
bec55c46dd
commit
505d7d2033
|
@ -3,5 +3,5 @@ project(aoc_2021 C)
|
||||||
|
|
||||||
set(CMAKE_C_STANDARD 99)
|
set(CMAKE_C_STANDARD 99)
|
||||||
|
|
||||||
add_executable(aoc_2021 src/main.c src/day_1.c src/day.h src/day_2.c src/puzzle_input.c src/puzzle_input.h src/day_3.c)
|
add_executable(aoc_2021 src/main.c src/day_1.c src/day.h src/day_2.c src/puzzle_input.c src/puzzle_input.h src/day_3.c src/day_4.c)
|
||||||
target_link_libraries(aoc_2021 m)
|
target_link_libraries(aoc_2021 m)
|
||||||
|
|
|
@ -0,0 +1,601 @@
|
||||||
|
99,56,7,15,81,26,75,40,87,59,62,24,58,34,78,86,44,65,18,94,20,17,98,29,57,92,14,32,46,79,85,84,35,68,55,22,41,61,90,11,69,96,23,47,43,80,72,50,97,33,53,25,28,51,49,64,12,63,21,48,27,19,67,88,66,45,3,71,16,70,76,13,60,77,73,1,8,10,52,38,36,74,83,2,37,6,31,91,89,54,42,30,5,82,9,95,93,4,0,39
|
||||||
|
|
||||||
|
57 19 40 54 64
|
||||||
|
22 69 15 88 8
|
||||||
|
79 60 48 95 85
|
||||||
|
34 97 33 1 55
|
||||||
|
72 82 29 90 84
|
||||||
|
|
||||||
|
19 17 62 78 27
|
||||||
|
61 13 30 75 25
|
||||||
|
14 66 72 37 79
|
||||||
|
49 91 97 0 23
|
||||||
|
12 52 41 92 18
|
||||||
|
|
||||||
|
52 17 62 49 76
|
||||||
|
8 78 93 37 12
|
||||||
|
9 40 59 75 94
|
||||||
|
45 2 81 44 63
|
||||||
|
73 18 48 11 90
|
||||||
|
|
||||||
|
59 75 55 74 43
|
||||||
|
1 17 89 36 91
|
||||||
|
87 52 45 83 22
|
||||||
|
9 3 15 11 53
|
||||||
|
94 72 68 29 20
|
||||||
|
|
||||||
|
71 97 74 32 17
|
||||||
|
31 5 43 83 38
|
||||||
|
85 27 37 14 65
|
||||||
|
23 0 61 33 82
|
||||||
|
41 63 70 60 6
|
||||||
|
|
||||||
|
58 24 28 42 73
|
||||||
|
80 52 97 68 53
|
||||||
|
30 40 45 18 13
|
||||||
|
94 12 7 77 98
|
||||||
|
72 14 34 21 23
|
||||||
|
|
||||||
|
97 93 21 99 35
|
||||||
|
31 8 73 15 74
|
||||||
|
67 60 44 1 18
|
||||||
|
68 61 64 82 86
|
||||||
|
76 47 22 63 78
|
||||||
|
|
||||||
|
49 6 93 20 95
|
||||||
|
96 50 57 71 70
|
||||||
|
90 42 7 2 27
|
||||||
|
38 78 56 21 82
|
||||||
|
55 98 72 40 66
|
||||||
|
|
||||||
|
43 5 11 46 24
|
||||||
|
30 45 91 50 72
|
||||||
|
27 53 0 10 7
|
||||||
|
15 35 73 96 9
|
||||||
|
2 67 1 17 32
|
||||||
|
|
||||||
|
48 45 91 41 65
|
||||||
|
72 63 33 49 8
|
||||||
|
10 39 96 61 14
|
||||||
|
26 58 16 74 34
|
||||||
|
79 60 40 30 35
|
||||||
|
|
||||||
|
71 0 52 48 32
|
||||||
|
92 85 38 20 84
|
||||||
|
68 24 13 74 2
|
||||||
|
42 60 96 16 17
|
||||||
|
59 67 69 8 65
|
||||||
|
|
||||||
|
11 79 91 16 87
|
||||||
|
82 39 77 24 32
|
||||||
|
67 45 22 86 31
|
||||||
|
84 56 54 55 75
|
||||||
|
5 41 3 70 40
|
||||||
|
|
||||||
|
55 15 20 43 96
|
||||||
|
63 47 13 18 91
|
||||||
|
28 66 14 21 52
|
||||||
|
59 9 12 97 58
|
||||||
|
83 81 8 36 44
|
||||||
|
|
||||||
|
7 75 86 59 2
|
||||||
|
47 14 87 19 49
|
||||||
|
64 3 52 91 40
|
||||||
|
11 43 35 1 44
|
||||||
|
78 29 56 5 36
|
||||||
|
|
||||||
|
46 32 44 4 30
|
||||||
|
77 6 63 13 74
|
||||||
|
71 23 53 56 27
|
||||||
|
84 93 19 83 81
|
||||||
|
16 97 99 34 92
|
||||||
|
|
||||||
|
6 87 56 63 39
|
||||||
|
93 51 71 92 40
|
||||||
|
81 14 9 26 24
|
||||||
|
80 66 88 89 44
|
||||||
|
18 1 29 7 8
|
||||||
|
|
||||||
|
74 61 9 83 18
|
||||||
|
57 95 79 35 47
|
||||||
|
81 72 80 12 37
|
||||||
|
1 8 71 54 86
|
||||||
|
40 2 97 19 17
|
||||||
|
|
||||||
|
80 12 74 16 92
|
||||||
|
99 26 49 79 28
|
||||||
|
39 31 83 64 54
|
||||||
|
14 90 42 96 81
|
||||||
|
27 11 33 36 35
|
||||||
|
|
||||||
|
80 26 21 49 9
|
||||||
|
79 47 74 75 77
|
||||||
|
78 16 89 55 43
|
||||||
|
27 28 95 71 57
|
||||||
|
81 36 0 87 66
|
||||||
|
|
||||||
|
16 65 29 94 9
|
||||||
|
71 56 39 30 23
|
||||||
|
74 49 2 63 13
|
||||||
|
54 45 48 66 64
|
||||||
|
70 21 44 57 0
|
||||||
|
|
||||||
|
16 72 74 15 79
|
||||||
|
66 12 45 70 18
|
||||||
|
44 51 98 11 26
|
||||||
|
64 68 28 49 27
|
||||||
|
48 69 52 7 2
|
||||||
|
|
||||||
|
72 54 71 43 92
|
||||||
|
83 95 58 36 1
|
||||||
|
96 35 62 46 18
|
||||||
|
16 29 30 28 21
|
||||||
|
99 87 6 64 11
|
||||||
|
|
||||||
|
61 34 54 25 91
|
||||||
|
90 33 44 22 10
|
||||||
|
58 37 59 3 28
|
||||||
|
20 18 98 38 2
|
||||||
|
95 99 69 50 14
|
||||||
|
|
||||||
|
71 72 25 17 4
|
||||||
|
70 37 92 85 51
|
||||||
|
78 28 82 48 89
|
||||||
|
12 52 7 13 21
|
||||||
|
74 73 44 46 36
|
||||||
|
|
||||||
|
21 99 48 77 34
|
||||||
|
51 67 14 83 89
|
||||||
|
7 91 22 63 97
|
||||||
|
4 82 42 11 23
|
||||||
|
2 27 45 13 94
|
||||||
|
|
||||||
|
83 23 72 22 24
|
||||||
|
13 27 70 20 15
|
||||||
|
0 56 41 1 19
|
||||||
|
62 68 75 21 67
|
||||||
|
90 12 77 98 14
|
||||||
|
|
||||||
|
56 63 78 71 51
|
||||||
|
22 18 33 92 65
|
||||||
|
89 12 45 82 73
|
||||||
|
13 34 37 48 97
|
||||||
|
42 85 54 4 53
|
||||||
|
|
||||||
|
74 70 52 96 41
|
||||||
|
93 36 73 81 4
|
||||||
|
63 71 0 3 57
|
||||||
|
51 54 94 25 24
|
||||||
|
88 80 22 17 16
|
||||||
|
|
||||||
|
0 70 60 17 3
|
||||||
|
66 80 73 84 99
|
||||||
|
34 69 22 90 72
|
||||||
|
15 41 6 39 76
|
||||||
|
94 9 98 91 75
|
||||||
|
|
||||||
|
17 20 4 19 79
|
||||||
|
30 42 0 11 2
|
||||||
|
37 28 95 14 71
|
||||||
|
61 81 39 12 82
|
||||||
|
33 44 69 29 26
|
||||||
|
|
||||||
|
87 98 74 96 15
|
||||||
|
2 61 1 52 23
|
||||||
|
49 81 0 99 69
|
||||||
|
47 35 55 60 36
|
||||||
|
94 19 29 63 53
|
||||||
|
|
||||||
|
84 95 22 54 93
|
||||||
|
98 94 7 5 30
|
||||||
|
4 46 28 68 90
|
||||||
|
15 29 71 73 66
|
||||||
|
42 44 45 82 10
|
||||||
|
|
||||||
|
28 66 41 39 92
|
||||||
|
61 63 27 40 38
|
||||||
|
42 73 53 52 81
|
||||||
|
62 78 96 82 51
|
||||||
|
59 68 64 93 16
|
||||||
|
|
||||||
|
48 49 51 85 12
|
||||||
|
90 81 18 73 30
|
||||||
|
67 46 38 60 17
|
||||||
|
10 86 62 66 84
|
||||||
|
98 36 99 8 45
|
||||||
|
|
||||||
|
11 53 78 32 83
|
||||||
|
94 0 80 67 37
|
||||||
|
76 7 34 20 1
|
||||||
|
12 25 73 71 28
|
||||||
|
48 14 29 40 23
|
||||||
|
|
||||||
|
35 98 14 33 11
|
||||||
|
19 66 96 77 44
|
||||||
|
32 50 15 49 70
|
||||||
|
75 59 90 43 58
|
||||||
|
23 45 78 18 95
|
||||||
|
|
||||||
|
35 49 20 72 56
|
||||||
|
12 70 3 5 58
|
||||||
|
83 60 61 73 63
|
||||||
|
45 78 98 95 19
|
||||||
|
80 11 92 82 13
|
||||||
|
|
||||||
|
69 0 37 63 41
|
||||||
|
75 70 34 64 54
|
||||||
|
10 1 59 9 65
|
||||||
|
90 78 87 71 66
|
||||||
|
74 35 29 58 20
|
||||||
|
|
||||||
|
60 39 66 68 28
|
||||||
|
90 64 36 93 2
|
||||||
|
37 57 69 91 20
|
||||||
|
73 96 50 86 77
|
||||||
|
87 14 63 38 98
|
||||||
|
|
||||||
|
43 89 14 74 12
|
||||||
|
65 94 71 2 93
|
||||||
|
76 37 96 47 92
|
||||||
|
55 25 90 83 88
|
||||||
|
79 11 59 50 81
|
||||||
|
|
||||||
|
62 85 98 67 19
|
||||||
|
79 17 71 53 93
|
||||||
|
13 50 88 28 58
|
||||||
|
36 20 52 66 27
|
||||||
|
89 48 24 12 77
|
||||||
|
|
||||||
|
73 13 3 97 16
|
||||||
|
40 14 4 47 88
|
||||||
|
12 79 56 80 60
|
||||||
|
27 6 94 1 75
|
||||||
|
72 22 44 62 24
|
||||||
|
|
||||||
|
29 77 70 61 95
|
||||||
|
63 57 41 12 7
|
||||||
|
22 99 58 31 81
|
||||||
|
15 3 48 20 36
|
||||||
|
8 76 87 23 91
|
||||||
|
|
||||||
|
61 79 53 73 59
|
||||||
|
67 34 37 54 15
|
||||||
|
29 50 64 56 44
|
||||||
|
93 51 0 18 17
|
||||||
|
27 35 89 3 60
|
||||||
|
|
||||||
|
79 23 31 48 12
|
||||||
|
37 96 74 63 4
|
||||||
|
98 18 69 6 0
|
||||||
|
47 54 34 82 46
|
||||||
|
5 86 64 60 99
|
||||||
|
|
||||||
|
44 70 50 53 62
|
||||||
|
15 61 45 74 52
|
||||||
|
35 48 99 12 49
|
||||||
|
91 26 47 78 0
|
||||||
|
58 82 94 73 7
|
||||||
|
|
||||||
|
2 64 81 48 83
|
||||||
|
66 85 91 26 47
|
||||||
|
50 95 70 54 13
|
||||||
|
39 89 44 67 6
|
||||||
|
22 0 40 21 1
|
||||||
|
|
||||||
|
86 63 21 73 61
|
||||||
|
91 33 68 66 36
|
||||||
|
77 53 16 51 85
|
||||||
|
11 57 12 22 80
|
||||||
|
99 40 8 30 81
|
||||||
|
|
||||||
|
27 35 60 28 95
|
||||||
|
44 34 8 73 81
|
||||||
|
11 26 90 32 10
|
||||||
|
0 49 98 7 18
|
||||||
|
55 42 86 72 77
|
||||||
|
|
||||||
|
16 15 65 86 88
|
||||||
|
21 98 74 93 3
|
||||||
|
18 7 5 35 73
|
||||||
|
62 84 42 60 81
|
||||||
|
48 34 39 57 99
|
||||||
|
|
||||||
|
45 60 95 62 18
|
||||||
|
82 86 99 39 77
|
||||||
|
48 54 97 16 25
|
||||||
|
40 56 23 47 37
|
||||||
|
83 68 51 90 13
|
||||||
|
|
||||||
|
80 72 81 78 69
|
||||||
|
74 76 33 51 91
|
||||||
|
54 86 60 35 17
|
||||||
|
70 61 43 97 49
|
||||||
|
21 26 28 85 57
|
||||||
|
|
||||||
|
19 45 43 59 10
|
||||||
|
46 20 44 67 94
|
||||||
|
70 53 96 78 76
|
||||||
|
17 18 54 39 38
|
||||||
|
66 40 33 71 83
|
||||||
|
|
||||||
|
0 42 60 99 41
|
||||||
|
14 96 75 93 74
|
||||||
|
11 90 62 37 38
|
||||||
|
29 64 27 53 85
|
||||||
|
94 28 31 32 24
|
||||||
|
|
||||||
|
14 19 83 98 53
|
||||||
|
24 78 25 85 37
|
||||||
|
39 2 41 4 32
|
||||||
|
45 79 26 36 96
|
||||||
|
64 80 73 13 28
|
||||||
|
|
||||||
|
77 1 9 26 10
|
||||||
|
37 60 69 72 81
|
||||||
|
16 35 61 75 29
|
||||||
|
42 53 82 67 36
|
||||||
|
98 89 21 87 15
|
||||||
|
|
||||||
|
45 73 88 75 46
|
||||||
|
83 59 20 37 26
|
||||||
|
62 42 9 78 17
|
||||||
|
60 84 32 90 64
|
||||||
|
40 99 61 80 48
|
||||||
|
|
||||||
|
13 59 79 20 91
|
||||||
|
64 65 21 82 44
|
||||||
|
98 62 33 96 48
|
||||||
|
46 37 40 8 70
|
||||||
|
28 90 27 45 68
|
||||||
|
|
||||||
|
48 94 58 96 81
|
||||||
|
33 75 73 52 64
|
||||||
|
23 36 67 27 54
|
||||||
|
80 68 87 37 2
|
||||||
|
34 47 6 30 60
|
||||||
|
|
||||||
|
44 52 99 65 58
|
||||||
|
77 78 68 48 94
|
||||||
|
84 81 53 20 79
|
||||||
|
14 7 3 46 42
|
||||||
|
24 19 8 16 27
|
||||||
|
|
||||||
|
42 89 86 46 83
|
||||||
|
43 11 25 56 59
|
||||||
|
69 82 65 55 34
|
||||||
|
22 93 73 74 3
|
||||||
|
26 30 60 29 45
|
||||||
|
|
||||||
|
9 43 72 89 42
|
||||||
|
39 24 25 28 69
|
||||||
|
8 51 59 7 13
|
||||||
|
64 94 30 99 65
|
||||||
|
2 56 55 38 15
|
||||||
|
|
||||||
|
54 83 69 44 27
|
||||||
|
52 25 17 20 28
|
||||||
|
59 6 79 13 21
|
||||||
|
34 14 61 84 67
|
||||||
|
71 26 80 41 18
|
||||||
|
|
||||||
|
96 33 72 16 93
|
||||||
|
35 18 99 67 68
|
||||||
|
47 27 32 94 12
|
||||||
|
10 45 20 91 11
|
||||||
|
66 52 15 2 13
|
||||||
|
|
||||||
|
43 80 4 79 17
|
||||||
|
89 66 20 82 3
|
||||||
|
37 12 76 90 35
|
||||||
|
52 77 63 48 44
|
||||||
|
58 6 39 71 95
|
||||||
|
|
||||||
|
68 56 49 17 61
|
||||||
|
59 39 34 70 6
|
||||||
|
75 13 4 26 41
|
||||||
|
54 29 2 92 24
|
||||||
|
65 31 60 90 72
|
||||||
|
|
||||||
|
74 71 21 86 18
|
||||||
|
63 30 53 73 48
|
||||||
|
36 55 87 96 79
|
||||||
|
32 89 49 81 83
|
||||||
|
45 26 28 22 62
|
||||||
|
|
||||||
|
59 47 97 77 75
|
||||||
|
25 78 24 66 95
|
||||||
|
63 16 93 22 32
|
||||||
|
88 61 76 40 45
|
||||||
|
18 28 51 55 20
|
||||||
|
|
||||||
|
39 23 29 57 49
|
||||||
|
22 6 74 71 25
|
||||||
|
80 27 65 69 64
|
||||||
|
41 21 12 58 95
|
||||||
|
5 43 11 4 36
|
||||||
|
|
||||||
|
97 34 31 96 67
|
||||||
|
86 24 30 6 69
|
||||||
|
16 79 12 56 93
|
||||||
|
18 35 58 90 11
|
||||||
|
29 81 85 98 23
|
||||||
|
|
||||||
|
16 40 59 19 87
|
||||||
|
42 88 30 32 82
|
||||||
|
17 93 1 50 56
|
||||||
|
18 13 78 38 80
|
||||||
|
51 14 73 8 22
|
||||||
|
|
||||||
|
83 15 88 81 7
|
||||||
|
99 51 13 92 31
|
||||||
|
24 39 0 10 3
|
||||||
|
95 72 33 73 44
|
||||||
|
19 34 37 47 42
|
||||||
|
|
||||||
|
67 3 65 91 32
|
||||||
|
63 82 45 96 11
|
||||||
|
33 78 66 43 83
|
||||||
|
49 60 62 51 47
|
||||||
|
34 48 26 27 54
|
||||||
|
|
||||||
|
1 0 53 40 28
|
||||||
|
21 30 50 74 63
|
||||||
|
48 49 6 55 57
|
||||||
|
66 23 45 98 39
|
||||||
|
95 54 86 38 90
|
||||||
|
|
||||||
|
29 80 13 87 76
|
||||||
|
75 10 43 95 83
|
||||||
|
61 20 48 54 18
|
||||||
|
21 37 63 68 2
|
||||||
|
14 73 27 31 25
|
||||||
|
|
||||||
|
17 70 57 33 22
|
||||||
|
66 48 53 46 75
|
||||||
|
74 73 84 63 14
|
||||||
|
71 72 59 3 92
|
||||||
|
43 30 94 8 69
|
||||||
|
|
||||||
|
76 44 40 87 46
|
||||||
|
13 83 0 6 17
|
||||||
|
47 81 77 86 60
|
||||||
|
38 23 55 89 82
|
||||||
|
73 42 54 35 52
|
||||||
|
|
||||||
|
13 1 45 96 89
|
||||||
|
57 65 28 27 32
|
||||||
|
22 26 46 86 10
|
||||||
|
20 52 76 94 37
|
||||||
|
92 0 64 55 16
|
||||||
|
|
||||||
|
28 11 26 64 78
|
||||||
|
15 7 75 96 61
|
||||||
|
35 83 18 8 53
|
||||||
|
57 1 13 66 79
|
||||||
|
84 47 6 43 80
|
||||||
|
|
||||||
|
25 80 70 2 59
|
||||||
|
44 36 98 85 76
|
||||||
|
87 7 42 83 94
|
||||||
|
62 40 81 33 52
|
||||||
|
10 65 14 60 26
|
||||||
|
|
||||||
|
19 83 26 87 91
|
||||||
|
23 57 40 36 15
|
||||||
|
1 54 8 49 31
|
||||||
|
64 5 59 88 45
|
||||||
|
69 18 58 11 62
|
||||||
|
|
||||||
|
92 65 73 33 12
|
||||||
|
13 30 18 66 11
|
||||||
|
55 51 97 99 26
|
||||||
|
57 31 71 49 41
|
||||||
|
6 95 19 35 25
|
||||||
|
|
||||||
|
64 9 77 92 43
|
||||||
|
88 80 75 58 32
|
||||||
|
33 97 53 27 23
|
||||||
|
85 14 35 42 45
|
||||||
|
44 95 89 61 40
|
||||||
|
|
||||||
|
22 68 27 75 76
|
||||||
|
95 45 80 10 14
|
||||||
|
24 19 71 11 50
|
||||||
|
74 41 88 8 0
|
||||||
|
99 42 13 90 77
|
||||||
|
|
||||||
|
83 59 56 8 58
|
||||||
|
30 73 67 82 1
|
||||||
|
51 84 44 33 57
|
||||||
|
76 16 4 13 87
|
||||||
|
6 95 72 27 38
|
||||||
|
|
||||||
|
60 14 37 78 73
|
||||||
|
80 40 58 30 64
|
||||||
|
77 92 81 1 45
|
||||||
|
79 26 11 12 51
|
||||||
|
25 56 68 67 61
|
||||||
|
|
||||||
|
5 20 59 4 96
|
||||||
|
6 78 60 73 50
|
||||||
|
88 7 48 2 35
|
||||||
|
30 87 10 81 40
|
||||||
|
1 84 83 22 75
|
||||||
|
|
||||||
|
20 91 9 21 59
|
||||||
|
30 69 60 55 37
|
||||||
|
63 57 77 12 45
|
||||||
|
28 64 56 95 22
|
||||||
|
33 84 92 48 86
|
||||||
|
|
||||||
|
75 62 83 32 91
|
||||||
|
93 44 22 84 76
|
||||||
|
74 34 90 59 33
|
||||||
|
78 54 71 12 25
|
||||||
|
10 95 14 43 28
|
||||||
|
|
||||||
|
48 36 10 85 5
|
||||||
|
40 69 91 72 63
|
||||||
|
37 22 55 94 93
|
||||||
|
16 26 21 38 35
|
||||||
|
31 2 52 20 1
|
||||||
|
|
||||||
|
28 85 3 4 27
|
||||||
|
77 18 26 50 62
|
||||||
|
78 86 52 79 59
|
||||||
|
58 48 54 64 41
|
||||||
|
25 2 57 44 10
|
||||||
|
|
||||||
|
15 35 22 41 26
|
||||||
|
2 39 88 69 84
|
||||||
|
45 44 33 99 11
|
||||||
|
91 20 85 32 46
|
||||||
|
83 66 61 30 89
|
||||||
|
|
||||||
|
14 0 97 1 7
|
||||||
|
49 15 85 93 35
|
||||||
|
73 90 61 8 6
|
||||||
|
52 17 16 67 39
|
||||||
|
91 84 25 24 66
|
||||||
|
|
||||||
|
68 3 15 90 51
|
||||||
|
59 62 11 61 83
|
||||||
|
97 84 94 55 20
|
||||||
|
71 8 1 70 73
|
||||||
|
88 43 89 57 4
|
||||||
|
|
||||||
|
61 30 53 8 70
|
||||||
|
47 25 2 41 43
|
||||||
|
99 65 96 68 66
|
||||||
|
90 78 57 64 52
|
||||||
|
42 95 48 40 86
|
||||||
|
|
||||||
|
44 27 1 25 62
|
||||||
|
92 81 5 11 40
|
||||||
|
24 33 34 37 3
|
||||||
|
47 28 94 58 26
|
||||||
|
72 80 71 57 7
|
||||||
|
|
||||||
|
54 55 73 99 9
|
||||||
|
26 88 48 75 12
|
||||||
|
65 84 71 85 96
|
||||||
|
72 87 28 66 35
|
||||||
|
89 63 15 44 69
|
||||||
|
|
||||||
|
92 36 31 72 85
|
||||||
|
33 93 69 65 84
|
||||||
|
74 77 11 59 52
|
||||||
|
6 12 34 10 45
|
||||||
|
63 30 55 46 15
|
||||||
|
|
||||||
|
1 59 15 45 75
|
||||||
|
25 31 70 78 11
|
||||||
|
36 12 34 8 79
|
||||||
|
99 57 20 95 72
|
||||||
|
23 50 19 73 22
|
||||||
|
|
||||||
|
38 66 51 93 39
|
||||||
|
12 96 99 36 97
|
||||||
|
40 21 95 10 94
|
||||||
|
3 22 18 26 49
|
||||||
|
91 61 73 70 47
|
|
@ -4,5 +4,6 @@
|
||||||
int day_1();
|
int day_1();
|
||||||
int day_2();
|
int day_2();
|
||||||
int day_3();
|
int day_3();
|
||||||
|
int day_4();
|
||||||
|
|
||||||
#endif //AOC_2021_DAY_H
|
#endif //AOC_2021_DAY_H
|
||||||
|
|
|
@ -48,7 +48,7 @@ int day_1() {
|
||||||
uint16_t data_len;
|
uint16_t data_len;
|
||||||
int64_t data[DATA_MAX_LEN];
|
int64_t data[DATA_MAX_LEN];
|
||||||
|
|
||||||
parse_ret_t res = read_input(path, (void *)data, DATA_MAX_LEN, parse_long_from_buff, &data_len);
|
parse_ret_t res = read_input_single_line(path, (void *) data, DATA_MAX_LEN, parse_long_from_buff, &data_len);
|
||||||
|
|
||||||
if (res == PARSER_OK) {
|
if (res == PARSER_OK) {
|
||||||
part_1(data, data_len);
|
part_1(data, data_len);
|
||||||
|
|
|
@ -104,7 +104,9 @@ static void part_2(course_entry_t * course, uint16_t course_len) {
|
||||||
int day_2() {
|
int day_2() {
|
||||||
course_entry_t course[MAX_COURSE_SIZE];
|
course_entry_t course[MAX_COURSE_SIZE];
|
||||||
uint16_t data_len;
|
uint16_t data_len;
|
||||||
parse_ret_t res = read_input("../inputs/day_2.txt", (void *)course, MAX_COURSE_SIZE, parse_course_entry, &data_len);
|
parse_ret_t res = read_input_single_line("../inputs/day_2.txt", (void *) course, MAX_COURSE_SIZE,
|
||||||
|
parse_course_entry,
|
||||||
|
&data_len);
|
||||||
|
|
||||||
if (res == PARSER_OK) {
|
if (res == PARSER_OK) {
|
||||||
part_1(course, data_len);
|
part_1(course, data_len);
|
||||||
|
|
|
@ -121,7 +121,8 @@ int day_3() {
|
||||||
uint16_t len;
|
uint16_t len;
|
||||||
parse_ret_t parse_ret;
|
parse_ret_t parse_ret;
|
||||||
|
|
||||||
parse_ret = read_input("../inputs/day_3.txt", (void *)diagnostic_data_g, DIAGNOSTIC_LEN, parse_diagnostic_data, &len);
|
parse_ret = read_input_single_line("../inputs/day_3.txt", (void *) diagnostic_data_g, DIAGNOSTIC_LEN,
|
||||||
|
parse_diagnostic_data, &len);
|
||||||
|
|
||||||
if (parse_ret != PARSER_OK) {
|
if (parse_ret != PARSER_OK) {
|
||||||
printf("Unable to parse input data: %d", parse_ret);
|
printf("Unable to parse input data: %d", parse_ret);
|
||||||
|
|
|
@ -0,0 +1,189 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "puzzle_input.h"
|
||||||
|
#include "day.h"
|
||||||
|
|
||||||
|
#define BINGO_BOARD_SIZE 5
|
||||||
|
#define MAX_BINGO_BOARDS 101
|
||||||
|
#define MAX_DRAWS 100
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint8_t board[BINGO_BOARD_SIZE][BINGO_BOARD_SIZE];
|
||||||
|
uint8_t matches[BINGO_BOARD_SIZE][BINGO_BOARD_SIZE];
|
||||||
|
uint8_t won;
|
||||||
|
} bingo_board_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint8_t num_boards;
|
||||||
|
uint8_t num_draws;
|
||||||
|
bingo_board_t boards[MAX_BINGO_BOARDS];
|
||||||
|
uint8_t draws[MAX_DRAWS];
|
||||||
|
} bingo_input_t;
|
||||||
|
|
||||||
|
parse_ret_t parse_bingo_input(char * buffer, void * data, uint16_t index) {
|
||||||
|
bingo_input_t * bingo_data = (bingo_input_t *)data;
|
||||||
|
char * tok;
|
||||||
|
parse_ret_t res;
|
||||||
|
|
||||||
|
if (index == 0) {
|
||||||
|
uint8_t draw_ndx = 0;
|
||||||
|
tok = strtok(buffer, ",");
|
||||||
|
|
||||||
|
while (tok != NULL) {
|
||||||
|
int64_t draw_val;
|
||||||
|
res = parse_long(tok, &draw_val, 10);
|
||||||
|
|
||||||
|
if (res != PARSER_OK) {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
bingo_data->draws[draw_ndx] = (uint8_t)draw_val;
|
||||||
|
draw_ndx++;
|
||||||
|
tok = strtok(NULL, ",");
|
||||||
|
}
|
||||||
|
|
||||||
|
bingo_data->num_draws = draw_ndx+1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
index--; // skip the draws line
|
||||||
|
tok = strtok(buffer, " ");
|
||||||
|
for (int row = 0; row < BINGO_BOARD_SIZE; row++) {
|
||||||
|
for (int col = 0; col < BINGO_BOARD_SIZE; col++) {
|
||||||
|
int64_t val;
|
||||||
|
|
||||||
|
res = parse_long(tok, &val, 10);
|
||||||
|
|
||||||
|
if (res != PARSER_OK) {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
bingo_data->boards[index].board[row][col] = (uint8_t)val;
|
||||||
|
tok = strtok(NULL, " ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bingo_data->num_boards++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return PARSER_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
bingo_input_t bingo_input_g = {
|
||||||
|
.num_boards = 0,
|
||||||
|
.num_draws = 0,
|
||||||
|
.boards = {0},
|
||||||
|
};
|
||||||
|
|
||||||
|
uint32_t calc_score(bingo_board_t * board, uint8_t final_number) {
|
||||||
|
uint32_t sum = 0;
|
||||||
|
for (int row = 0; row < BINGO_BOARD_SIZE; row++) {
|
||||||
|
for (int col = 0; col < BINGO_BOARD_SIZE; col++) {
|
||||||
|
if (!board->matches[row][col]) {
|
||||||
|
sum += board->board[row][col];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return sum*final_number;
|
||||||
|
}
|
||||||
|
|
||||||
|
int day_4() {
|
||||||
|
uint16_t len;
|
||||||
|
uint8_t first_winner_found = 0;
|
||||||
|
|
||||||
|
int32_t winner_count = 0;
|
||||||
|
int32_t last_winner_ndx = -1;
|
||||||
|
int32_t last_winner_number = -1;
|
||||||
|
|
||||||
|
uint32_t score;
|
||||||
|
|
||||||
|
parse_ret_t res = read_input_multi_line("../inputs/day_4.txt", (void *)&bingo_input_g, MAX_BINGO_BOARDS+1, "", parse_bingo_input, &len);
|
||||||
|
|
||||||
|
if (res != PARSER_OK) {
|
||||||
|
printf("Failed to parse input: %d", res);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int draw_ndx = 0; draw_ndx < bingo_input_g.num_draws; draw_ndx++) {
|
||||||
|
uint16_t draw = bingo_input_g.draws[draw_ndx];
|
||||||
|
|
||||||
|
for (int board_ndx = 0; board_ndx < bingo_input_g.num_boards; board_ndx++) {
|
||||||
|
uint8_t match_found = 0;
|
||||||
|
bingo_board_t *board = &bingo_input_g.boards[board_ndx];
|
||||||
|
for (int row = 0; row < BINGO_BOARD_SIZE; row++) {
|
||||||
|
for (int col = 0; col < BINGO_BOARD_SIZE; col++) {
|
||||||
|
if (board->board[row][col] == draw) {
|
||||||
|
board->matches[row][col] = 1;
|
||||||
|
match_found = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (match_found) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!board->won) {
|
||||||
|
uint8_t won_flag = 0;
|
||||||
|
|
||||||
|
for (int row = 0; row < BINGO_BOARD_SIZE; row++) {
|
||||||
|
if (board->matches[row][0] && board->matches[row][1] && board->matches[row][2] &&
|
||||||
|
board->matches[row][3] && board->matches[row][4]) {
|
||||||
|
if (!first_winner_found) {
|
||||||
|
first_winner_found = 1;
|
||||||
|
score = calc_score(board, draw);
|
||||||
|
}
|
||||||
|
|
||||||
|
winner_count++;
|
||||||
|
board->won = 1;
|
||||||
|
won_flag = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!won_flag) {
|
||||||
|
for (int col = 0; col < BINGO_BOARD_SIZE; col++) {
|
||||||
|
if (board->matches[0][col] && board->matches[1][col] && board->matches[2][col] &&
|
||||||
|
board->matches[3][col] && board->matches[4][col]) {
|
||||||
|
if (!first_winner_found) {
|
||||||
|
first_winner_found = 1;
|
||||||
|
score = calc_score(board, draw);
|
||||||
|
}
|
||||||
|
board->won = 1;
|
||||||
|
winner_count++;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (winner_count == bingo_input_g.num_boards) {
|
||||||
|
last_winner_ndx = board_ndx;
|
||||||
|
last_winner_number = draw;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (last_winner_ndx >= 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (first_winner_found == 0) {
|
||||||
|
printf("Something went wrong, no winner was found\n");
|
||||||
|
return -2;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("PART 1: The final score was %d\n", score);
|
||||||
|
|
||||||
|
if (last_winner_ndx < 0) {
|
||||||
|
printf("Something went wrong, no last winner was found\n");
|
||||||
|
return -3;
|
||||||
|
}
|
||||||
|
uint32_t last_score = calc_score(&bingo_input_g.boards[last_winner_ndx], last_winner_number);
|
||||||
|
printf("PART 2: The final score of the last board was %d\n", last_score);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -25,6 +25,9 @@ int main(int argc, char * argv[]) {
|
||||||
case 3:
|
case 3:
|
||||||
day_3();
|
day_3();
|
||||||
break;
|
break;
|
||||||
|
case 4:
|
||||||
|
day_4();
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
printf("Invalid day ding dong!\n");
|
printf("Invalid day ding dong!\n");
|
||||||
return -2;
|
return -2;
|
||||||
|
|
|
@ -2,9 +2,16 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
#include "puzzle_input.h"
|
#include "puzzle_input.h"
|
||||||
|
|
||||||
|
#define BUFFER_SIZE 256
|
||||||
|
|
||||||
parse_ret_t parse_long(char * buffer, int64_t *val, int16_t base) {
|
parse_ret_t parse_long(char * buffer, int64_t *val, int16_t base) {
|
||||||
|
if (buffer == NULL) {
|
||||||
|
return PARSE_NULL;
|
||||||
|
}
|
||||||
|
|
||||||
*val = strtol(buffer, NULL, base);
|
*val = strtol(buffer, NULL, base);
|
||||||
|
|
||||||
if (*val == LONG_MIN || *val == LONG_MAX) {
|
if (*val == LONG_MIN || *val == LONG_MAX) {
|
||||||
|
@ -20,7 +27,7 @@ static parse_ret_t parse_long_base_from_buff(char * buffer, void * data, uint16_
|
||||||
uint64_t val;
|
uint64_t val;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = parse_long(buffer, (int64_t *)&val, base);
|
ret = parse_long(buffer, (int64_t *)&val, (int16_t)base);
|
||||||
|
|
||||||
if (ret != PARSER_OK) {
|
if (ret != PARSER_OK) {
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -39,8 +46,8 @@ parse_ret_t parse_long_base_2_from_buff(char * buffer, void * data, uint16_t ind
|
||||||
return parse_long_base_from_buff(buffer, data, index, 2);
|
return parse_long_base_from_buff(buffer, data, index, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
parse_ret_t read_input(const char * file_path, void * data, uint16_t max_len, input_parser_t parser, uint16_t * len) {
|
parse_ret_t read_input_single_line(const char * file_path, void * data, uint16_t max_len, input_parser_t parser, uint16_t * len) {
|
||||||
char buffer[64];
|
char buffer[BUFFER_SIZE];
|
||||||
int c;
|
int c;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
FILE * file = fopen(file_path, "r");
|
FILE * file = fopen(file_path, "r");
|
||||||
|
@ -93,3 +100,78 @@ parse_ret_t read_input(const char * file_path, void * data, uint16_t max_len, in
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char buffer_g[BUFFER_SIZE];
|
||||||
|
char line_buffer_g[BUFFER_SIZE];
|
||||||
|
|
||||||
|
parse_ret_t read_input_multi_line(const char * file_path, void * data, uint16_t max_len, char * line_sep, input_parser_t parser, uint16_t * len) {
|
||||||
|
int c;
|
||||||
|
int ret = 0;
|
||||||
|
FILE * file = fopen(file_path, "r");
|
||||||
|
uint16_t data_ndx = 0;
|
||||||
|
|
||||||
|
if (file != NULL) {
|
||||||
|
int buffer_ndx = 0;
|
||||||
|
int line_buffer_ndx = 0;
|
||||||
|
while ((c = fgetc(file)) != EOF) {
|
||||||
|
if (c == '\n') {
|
||||||
|
line_buffer_g[line_buffer_ndx] = 0;
|
||||||
|
|
||||||
|
if (strcmp(line_buffer_g, line_sep) == 0) {
|
||||||
|
ret = parser(buffer_g, data, data_ndx);
|
||||||
|
|
||||||
|
if (ret != PARSER_OK) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
data_ndx++;
|
||||||
|
buffer_ndx = 0;
|
||||||
|
|
||||||
|
if (data_ndx >= max_len) {
|
||||||
|
ret = PARSER_RANGE_OVERFLOW;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
strncpy(&buffer_g[buffer_ndx], line_buffer_g, line_buffer_ndx);
|
||||||
|
buffer_ndx += line_buffer_ndx;
|
||||||
|
buffer_g[buffer_ndx++] = ' ';
|
||||||
|
}
|
||||||
|
|
||||||
|
line_buffer_ndx = 0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
line_buffer_g[line_buffer_ndx] = (char)c;
|
||||||
|
line_buffer_ndx++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (buffer_ndx > 0) {
|
||||||
|
strncpy(&buffer_g[buffer_ndx], line_buffer_g, line_buffer_ndx);
|
||||||
|
buffer_ndx += line_buffer_ndx;
|
||||||
|
buffer_g[buffer_ndx++] = ' ';
|
||||||
|
ret = parser(buffer_g, data, data_ndx);
|
||||||
|
|
||||||
|
if (ret != PARSER_OK) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
data_ndx++;
|
||||||
|
|
||||||
|
if (data_ndx >= max_len) {
|
||||||
|
return PARSER_RANGE_OVERFLOW;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ret = PARSE_FILE_ERR;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (file != NULL) {
|
||||||
|
fclose(file);
|
||||||
|
}
|
||||||
|
|
||||||
|
*len = data_ndx;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
|
@ -8,11 +8,13 @@ typedef enum {
|
||||||
PARSER_INVALID = -1,
|
PARSER_INVALID = -1,
|
||||||
PARSER_RANGE_OVERFLOW = -2,
|
PARSER_RANGE_OVERFLOW = -2,
|
||||||
PARSE_FILE_ERR = -3,
|
PARSE_FILE_ERR = -3,
|
||||||
|
PARSE_NULL = -4,
|
||||||
} parse_ret_t;
|
} parse_ret_t;
|
||||||
|
|
||||||
typedef parse_ret_t (*input_parser_t)(char * buffer, void * data, uint16_t index);
|
typedef parse_ret_t (*input_parser_t)(char * buffer, void * data, uint16_t index);
|
||||||
|
|
||||||
parse_ret_t read_input(const char * file_path, void * data, uint16_t max_len, input_parser_t parser, uint16_t * len);
|
parse_ret_t read_input_single_line(const char * file_path, void * data, uint16_t max_len, input_parser_t parser, uint16_t * len);
|
||||||
|
parse_ret_t read_input_multi_line(const char * file_path, void * data, uint16_t max_len, char * sep, input_parser_t parser, uint16_t * len);
|
||||||
|
|
||||||
// Parsers
|
// Parsers
|
||||||
parse_ret_t parse_long_from_buff(char * buffer, void * data, uint16_t index);
|
parse_ret_t parse_long_from_buff(char * buffer, void * data, uint16_t index);
|
||||||
|
|
Loading…
Reference in New Issue