diff options
| author | Louis Burda <quent.burda@gmail.com> | 2023-04-08 12:40:30 -0400 |
|---|---|---|
| committer | Louis Burda <quent.burda@gmail.com> | 2023-04-09 10:21:36 -0400 |
| commit | 9282e95e8844afe856ba76ceb6d2c3010df8bb1a (patch) | |
| tree | e35affc89b20324371381e079f7cb5f8a06aa81b /src/06/main.zig | |
| parent | 2b5d4232879dc74491dabf54a0ddc958d66ebcec (diff) | |
| download | aoc2020-zig-master.tar.gz aoc2020-zig-master.zip | |
Diffstat (limited to 'src/06/main.zig')
| -rw-r--r-- | src/06/main.zig | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/06/main.zig b/src/06/main.zig new file mode 100644 index 0000000..b02576b --- /dev/null +++ b/src/06/main.zig @@ -0,0 +1,39 @@ +const std = @import("std"); +const aoc = @import("aoc"); + +fn part1(allocator: std.mem.Allocator, input: []u8, args: [][]u8) !?[]u8 { + _ = args; + + var entryit = std.mem.split(u8, input, "\n\n"); + var answer: u32 = 0; + while (entryit.next()) |group| { + var seen = [_]u1{0} ** 256; + for (group) |c| { + if (c == ' ' or c == '\n') continue; + answer += @boolToInt(seen[c] == 0); + seen[c] = 1; + } + } + + return try std.fmt.allocPrint(allocator, "{d}", .{answer}); +} + +fn part2(allocator: std.mem.Allocator, input: []u8, args: [][]u8) !?[]u8 { + _ = args; + + var entryit = std.mem.split(u8, input, "\n\n"); + var answer: u32 = 0; + while (entryit.next()) |group| { + var count = [_]u16{0} ** 256; + var members: u16 = 0; + var memberit = std.mem.tokenize(u8, group, "\n "); + while (memberit.next()) |member| : (members += 1) { + for (member) |c| count[c] += 1; + } + for (count) |v| answer += @boolToInt(v == members); + } + + return try std.fmt.allocPrint(allocator, "{d}", .{answer}); +} + +pub const main = aoc.main(part1, part2, .{ "6748", "3445" }); |
