day13: problem 2 solution

This commit is contained in:
Keenan Tims 2023-12-12 22:20:54 -08:00
parent f12e99c1f4
commit 5666aee5f2
Signed by: ktims
GPG Key ID: 11230674D69038D4

View File

@ -43,51 +43,75 @@ impl Pattern {
} }
fn find_horizontal_reflection(&self) -> Option<usize> { fn find_horizontal_reflection(&self) -> Option<usize> {
println!("looking for horiz: {:?}", (1..self.height() - 1).collect::<Vec<_>>());
(1..self.height()).find(|idx| self.is_horizontal_reflection(*idx)) (1..self.height()).find(|idx| self.is_horizontal_reflection(*idx))
} }
fn is_horizontal_reflection(&self, idx: usize) -> bool { fn is_horizontal_reflection(&self, idx: usize) -> bool {
let row_pairs = std::cmp::min(idx, self.height() - idx); let row_pairs = std::cmp::min(idx, self.height() - idx);
(0..row_pairs).all(|offset| { (0..row_pairs).all(|offset| self.mirrors[idx - offset - 1] == self.mirrors[idx + offset])
println!(
"{}: [{} == {}] {:?} == {:?}",
idx,
idx - offset - 1,
idx + offset,
self.mirrors[idx - offset - 1],
self.mirrors[idx + offset]
);
self.mirrors[idx - offset - 1] == self.mirrors[idx + offset]
})
} }
fn find_vertical_reflection(&self) -> Option<usize> { fn find_vertical_reflection(&self) -> Option<usize> {
println!("looking for vert: {:?}", (1..self.width() - 1).collect::<Vec<_>>()); (1..self.width()).find(|idx| self.is_vertical_reflection(*idx))
(1..self.width() ).find(|idx| self.is_vertical_reflection(*idx))
} }
fn is_vertical_reflection(&self, idx: usize) -> bool { fn is_vertical_reflection(&self, idx: usize) -> bool {
let col_pairs = std::cmp::min(idx, self.width() - idx); let col_pairs = std::cmp::min(idx, self.width() - idx);
(0..col_pairs).all(|offset| { (0..col_pairs).all(|offset| self.col(idx - offset - 1) == self.col(idx + offset))
println!( }
"{}: [{} == {}] {:?} == {:?}",
idx, fn find_smudged_horizontal_reflection(&self) -> Option<usize> {
idx - offset - 1, (1..self.height()).find(|idx| self.is_smudged_horizontal_reflection(*idx))
idx + offset, }
self.col(idx - offset - 1),
self.col(idx + offset) fn is_smudged_horizontal_reflection(&self, idx: usize) -> bool {
); // Same algorithm for problem 2, but count errors breaking reflection.
self.col(idx - offset - 1) == self.col(idx + offset) // If the count == 1 after all checks, then it is our smudge
let row_pairs = std::cmp::min(idx, self.height() - idx);
(0..row_pairs)
.map(|offset| {
self.mirrors[idx - offset - 1]
.iter()
.zip(self.mirrors[idx + offset].iter())
.filter(|(a, b)| **a != **b)
.count()
}) })
.sum::<usize>()
== 1
}
fn find_smudged_vertical_reflection(&self) -> Option<usize> {
(1..self.width()).find(|idx| self.is_smudged_vertical_reflection(*idx))
}
fn is_smudged_vertical_reflection(&self, idx: usize) -> bool {
let col_pairs = std::cmp::min(idx, self.width() - idx);
(0..col_pairs)
.map(|offset| {
self.col(idx - offset - 1)
.iter()
.zip(self.col(idx + offset).iter())
.filter(|(a, b)| **a != **b)
.count()
})
.sum::<usize>()
== 1
} }
fn reflection_cost(&self) -> u64 { fn reflection_cost(&self) -> u64 {
if let Some(refl) = self.find_horizontal_reflection() { if let Some(refl) = self.find_horizontal_reflection() {
println!("horizontal found at {}", refl);
100 * refl as u64 100 * refl as u64
} else if let Some(refl) = self.find_vertical_reflection() { } else if let Some(refl) = self.find_vertical_reflection() {
println!("vertical found at {}", refl); refl as u64
} else {
panic!("no reflection");
}
}
fn smudged_reflection_cost(&self) -> u64 {
if let Some(refl) = self.find_smudged_horizontal_reflection() {
100 * refl as u64
} else if let Some(refl) = self.find_smudged_vertical_reflection() {
refl as u64 refl as u64
} else { } else {
panic!("no reflection"); panic!("no reflection");
@ -125,13 +149,19 @@ fn problem1<T: BufRead>(input: Lines<T>) -> u64 {
patterns patterns
.patterns .patterns
.iter() .iter()
.map(|pat| { println!("{:?}", pat); pat.reflection_cost() }) .map(|pat| pat.reflection_cost())
.sum() .sum()
} }
// PROBLEM 2 solution // PROBLEM 2 solution
fn problem2<T: BufRead>(input: Lines<T>) -> u64 { fn problem2<T: BufRead>(input: Lines<T>) -> u64 {
0 let patterns = Patterns::from(input);
patterns
.patterns
.iter()
.map(|pat| pat.smudged_reflection_cost())
.sum()
} }
#[cfg(test)] #[cfg(test)]
@ -175,9 +205,23 @@ mod tests {
assert_eq!(problem1(c.lines()), 405); assert_eq!(problem1(c.lines()), 405);
} }
#[test]
fn problem2_find_horizontal() {
let c = Cursor::new(EXAMPLE);
let patterns = Patterns::from(c.lines());
assert_eq!(
patterns.patterns[0].find_smudged_horizontal_reflection(),
Some(3)
);
assert_eq!(
patterns.patterns[1].find_smudged_horizontal_reflection(),
Some(1)
);
}
#[test] #[test]
fn problem2_example() { fn problem2_example() {
let c = Cursor::new(EXAMPLE); let c = Cursor::new(EXAMPLE);
assert_eq!(problem2(c.lines()), 0); assert_eq!(problem2(c.lines()), 400);
} }
} }