Compare commits
2 Commits
283c49a7d8
...
84c562b5a8
| Author | SHA1 | Date | |
|---|---|---|---|
| 84c562b5a8 | |||
| 6b5aed016b |
45
Cargo.lock
generated
45
Cargo.lock
generated
@@ -7,6 +7,16 @@ name = "advent-of-rust-2024"
|
||||
version = "0.1.0"
|
||||
dependencies = [
|
||||
"itertools",
|
||||
"regex",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "aho-corasick"
|
||||
version = "1.1.3"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "8e60d3430d3a69478ad0993f19238d2df97c507009a52b3c10addcd7f6bcb916"
|
||||
dependencies = [
|
||||
"memchr",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
@@ -23,3 +33,38 @@ checksum = "413ee7dfc52ee1a4949ceeb7dbc8a33f2d6c088194d9f922fb8318faf1f01186"
|
||||
dependencies = [
|
||||
"either",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "memchr"
|
||||
version = "2.7.4"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3"
|
||||
|
||||
[[package]]
|
||||
name = "regex"
|
||||
version = "1.11.1"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "b544ef1b4eac5dc2db33ea63606ae9ffcfac26c1416a2806ae0bf5f56b201191"
|
||||
dependencies = [
|
||||
"aho-corasick",
|
||||
"memchr",
|
||||
"regex-automata",
|
||||
"regex-syntax",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "regex-automata"
|
||||
version = "0.4.9"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "809e8dc61f6de73b46c85f4c96486310fe304c434cfa43669d7b40f711150908"
|
||||
dependencies = [
|
||||
"aho-corasick",
|
||||
"memchr",
|
||||
"regex-syntax",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "regex-syntax"
|
||||
version = "0.8.5"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c"
|
||||
|
||||
@@ -5,3 +5,4 @@ edition = "2021"
|
||||
|
||||
[dependencies]
|
||||
itertools = "0.13.0"
|
||||
regex = "1.11.1"
|
||||
|
||||
76
src/day03.rs
76
src/day03.rs
@@ -1,35 +1,95 @@
|
||||
use itertools::Itertools;
|
||||
use std::fs::read_to_string;
|
||||
|
||||
pub fn day_main() {
|
||||
let input = read_to_string("input/day03.txt").unwrap();
|
||||
let input = input.trim();
|
||||
println!("part1: {}", part1(&input));
|
||||
println!("part2: {}", part2(&input));
|
||||
}
|
||||
|
||||
type RiddleResult = usize;
|
||||
type RiddleResult = i64;
|
||||
|
||||
fn part1(input: &str) -> RiddleResult {
|
||||
0
|
||||
let r = regex::Regex::new(r"mul\(\d{1,3},\d{1,3}\)").unwrap();
|
||||
r.captures_iter(input)
|
||||
.map(|c| {
|
||||
let s = c.get(0).unwrap().as_str();
|
||||
println!("{s}");
|
||||
let x = s.strip_prefix("mul(").unwrap().strip_suffix(")").unwrap();
|
||||
let (a, b) = x.split_once(',').unwrap();
|
||||
let a: i64 = a.parse().unwrap();
|
||||
let b: i64 = b.parse().unwrap();
|
||||
a * b
|
||||
})
|
||||
.sum()
|
||||
}
|
||||
|
||||
fn part2(_input: &str) -> RiddleResult {
|
||||
0
|
||||
enum Statement {
|
||||
Enable,
|
||||
Disable,
|
||||
Number(i64),
|
||||
}
|
||||
|
||||
fn part2(input: &str) -> RiddleResult {
|
||||
let r = regex::Regex::new(r"do\(\)|don't\(\)|mul\(\d{1,3},\d{1,3}\)").unwrap();
|
||||
let statements = r
|
||||
.captures_iter(input)
|
||||
.map(|c| {
|
||||
let s = c.get(0).unwrap().as_str();
|
||||
println!("{s}");
|
||||
|
||||
match s {
|
||||
"do()" => Statement::Enable,
|
||||
"don't()" => Statement::Disable,
|
||||
_ => {
|
||||
let x = s.strip_prefix("mul(").unwrap().strip_suffix(")").unwrap();
|
||||
let (a, b) = x.split_once(',').unwrap();
|
||||
let a: i64 = a.parse().unwrap();
|
||||
let b: i64 = b.parse().unwrap();
|
||||
Statement::Number(a * b)
|
||||
}
|
||||
}
|
||||
})
|
||||
.collect_vec();
|
||||
|
||||
let mut enabled = true;
|
||||
let mut result = 0;
|
||||
for f in statements {
|
||||
match f {
|
||||
Statement::Enable => {
|
||||
enabled = true;
|
||||
}
|
||||
Statement::Disable => {
|
||||
enabled = false;
|
||||
}
|
||||
Statement::Number(i) => {
|
||||
if enabled {
|
||||
result += i
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
result
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::{part1, part2};
|
||||
|
||||
const TEST_INPUT: &str = r"
|
||||
";
|
||||
const TEST_INPUT: &str =
|
||||
r"xmul(2,4)%&mul[3,7]!@^do_not_mul(5,5)+mul(32,64]then(mul(11,8)mul(8,5))";
|
||||
const TEST_INPUT2: &str =
|
||||
r"xmul(2,4)&mul[3,7]!^don't()_mul(5,5)+mul(32,64](mul(11,8)undo()?mul(8,5))";
|
||||
|
||||
#[test]
|
||||
fn test1() {
|
||||
assert_eq!(part1(TEST_INPUT), 0);
|
||||
assert_eq!(part1(TEST_INPUT), 161);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test2() {
|
||||
assert_eq!(part2(TEST_INPUT), 0);
|
||||
assert_eq!(part2(TEST_INPUT2), 48);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user