feat: day 4

This commit is contained in:
LordMZTE 2022-12-04 14:02:30 +01:00
parent f6c9985d1b
commit 226303936c
Signed by: LordMZTE
GPG Key ID: B64802DC33A64FF6
3 changed files with 1076 additions and 1 deletions

1000
input/day4.txt Normal file

File diff suppressed because it is too large Load Diff

74
src/days/day4.zig Normal file
View File

@ -0,0 +1,74 @@
const std = @import("std");
const aoc = @import("../aoc.zig");
pub const info = aoc.DayInfo{
.num = 4,
.name = "Camp Cleanup",
};
pub fn part1(alloc: std.mem.Allocator, infile: *std.fs.File) !void {
const input = try parse(alloc, infile);
defer input.deinit();
var sum: u32 = 0;
for (input.items) |r| {
if (rangesFullyContainEachother(r))
sum += 1;
}
try std.io.getStdOut().writer().print("{}\n", .{sum});
}
fn rangesFullyContainEachother(r: [2][2]u32) bool {
return (r[0][0] <= r[1][0] and r[0][1] >= r[1][1]) or
(r[1][0] <= r[0][0] and r[1][1] >= r[0][1]);
}
pub fn part2(alloc: std.mem.Allocator, infile: *std.fs.File) !void {
const input = try parse(alloc, infile);
defer input.deinit();
var sum: u32 = 0;
for (input.items) |r| {
if (rangesOverlap(r))
sum += 1;
}
try std.io.getStdOut().writer().print("{}\n", .{sum});
}
fn rangesOverlap(r: [2][2]u32) bool {
return r[0][0] <= r[1][1] and r[0][1] >= r[1][0];
}
fn parse(alloc: std.mem.Allocator, infile: *std.fs.File) !std.ArrayList([2][2]u32) {
var entries = std.ArrayList([2][2]u32).init(alloc);
errdefer entries.deinit();
var line_buf: [512]u8 = undefined;
while (try infile.reader().readUntilDelimiterOrEof(&line_buf, '\n')) |line| {
const trimmed = std.mem.trim(u8, line, &std.ascii.whitespace);
var entry = std.mem.zeroes([2][2]u32);
var splits1 = std.mem.tokenize(u8, trimmed, ",");
var idx1: usize = 0;
while (splits1.next()) |s1| {
var idx2: usize = 0;
var splits2 = std.mem.tokenize(u8, s1, "-");
while (splits2.next()) |s2| {
const num = try std.fmt.parseInt(u32, s2, 10);
entry[idx1][idx2] = num;
idx2 += 1;
}
idx1 += 1;
}
try entries.append(entry);
}
return entries;
}

View File

@ -4,7 +4,8 @@ const aoc = @import("aoc.zig");
const days = .{
//@import("days/day1.zig"),
//@import("days/day2.zig"),
@import("days/day3.zig"),
//@import("days/day3.zig"),
@import("days/day4.zig"),
};
pub fn main() !void {