2022-08-11 07:34:17 +00:00
|
|
|
const std = @import("std");
|
2022-08-13 13:34:20 +00:00
|
|
|
const util = @import("util.zig");
|
2022-08-11 07:34:17 +00:00
|
|
|
const Allocator = std.mem.Allocator;
|
2022-08-13 13:17:55 +00:00
|
|
|
const ArrayList = std.ArrayList;
|
2022-08-13 13:34:20 +00:00
|
|
|
const tokenize = std.mem.tokenize;
|
|
|
|
const print = std.debug.print;
|
2022-08-11 07:34:17 +00:00
|
|
|
const gpa = util.gpa;
|
|
|
|
|
2022-08-13 13:17:55 +00:00
|
|
|
const data = @embedFile("input");
|
2022-08-11 07:34:17 +00:00
|
|
|
|
|
|
|
pub fn main() !void {
|
2022-08-13 13:17:55 +00:00
|
|
|
|
|
|
|
// Still have no idea how to clean up the ArrayLists
|
|
|
|
var it = tokenize(u8, data, "\n");
|
|
|
|
var rows_al = ArrayList([]bool).init(gpa);
|
|
|
|
while (it.next()) |line| {
|
|
|
|
var row = ArrayList(bool).init(gpa);
|
|
|
|
for (line) |char| {
|
|
|
|
try row.append(char == '#');
|
|
|
|
}
|
|
|
|
try rows_al.append(row.toOwnedSlice());
|
|
|
|
}
|
|
|
|
var rows = rows_al.toOwnedSlice();
|
|
|
|
|
2022-08-13 13:34:20 +00:00
|
|
|
var part_1 = count_trees(rows, 3, 1);
|
|
|
|
print("Part 1: {}\n", .{part_1});
|
|
|
|
|
|
|
|
var part_2 = count_trees(rows, 1, 1) * part_1 * count_trees(rows, 5, 1) * count_trees(rows, 7, 1) * count_trees(rows, 1, 2);
|
|
|
|
|
|
|
|
print("Part 2: {}\n", .{part_2});
|
|
|
|
}
|
|
|
|
|
|
|
|
fn count_trees(slope: [][]bool, delta_x: usize, delta_y: usize) usize {
|
2022-08-13 13:17:55 +00:00
|
|
|
var x: usize = 0;
|
|
|
|
var y: usize = 0;
|
|
|
|
var count: usize = 0;
|
2022-08-13 13:34:20 +00:00
|
|
|
while (y < slope.len) {
|
|
|
|
var square = slope[y][x];
|
2022-08-13 13:17:55 +00:00
|
|
|
if (square) {
|
|
|
|
count += 1;
|
|
|
|
}
|
2022-08-13 13:34:20 +00:00
|
|
|
x = std.math.mod(usize, x + delta_x, slope[y].len) catch 0;
|
|
|
|
y += delta_y;
|
2022-08-13 13:17:55 +00:00
|
|
|
}
|
2022-08-13 13:34:20 +00:00
|
|
|
return count;
|
2022-08-11 07:34:17 +00:00
|
|
|
}
|