day 13
This commit is contained in:
parent
994be7e629
commit
16987a4bf8
|
@ -151,6 +151,14 @@ dependencies = [
|
|||
"nom",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "day-13"
|
||||
version = "0.0.0"
|
||||
dependencies = [
|
||||
"indoc",
|
||||
"rayon",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "deprecate-until"
|
||||
version = "0.1.1"
|
||||
|
|
|
@ -0,0 +1,12 @@
|
|||
[package]
|
||||
name = "day-13"
|
||||
version = "0.0.0"
|
||||
edition = "2021"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
||||
rayon.workspace = true
|
||||
|
||||
[dev-dependencies]
|
||||
indoc.workspace = true
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,65 @@
|
|||
fn main() {
|
||||
println!("{}", part1(include_str!("./input.txt")));
|
||||
}
|
||||
|
||||
fn part1(input: &str) -> usize {
|
||||
input.split("\n\n").map(process_pattern).sum()
|
||||
}
|
||||
|
||||
fn process_pattern(pattern: &str) -> usize {
|
||||
let lines = pattern
|
||||
.lines()
|
||||
.map(|s| s.chars().collect())
|
||||
.collect::<Vec<Vec<_>>>();
|
||||
let mut sum = check_for_reflection(lines.clone()) * 100;
|
||||
let width = lines[0].len();
|
||||
let columns = (0..width)
|
||||
.map(|i| lines.iter().map(|row| row[i]).collect::<Vec<char>>())
|
||||
.collect();
|
||||
sum += check_for_reflection(columns);
|
||||
|
||||
sum
|
||||
}
|
||||
|
||||
fn check_for_reflection(pattern: Vec<Vec<char>>) -> usize {
|
||||
(1..pattern.len())
|
||||
.find(|i| {
|
||||
let a = &pattern[0..*i];
|
||||
let b = &pattern[*i..];
|
||||
|
||||
a.iter().rev().zip(b).all(|(a, b)| a == b)
|
||||
})
|
||||
.unwrap_or(0)
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
use indoc::indoc;
|
||||
|
||||
#[test]
|
||||
fn test_part1() {
|
||||
assert_eq!(
|
||||
part1(indoc!(
|
||||
"
|
||||
#.##..##.
|
||||
..#.##.#.
|
||||
##......#
|
||||
##......#
|
||||
..#.##.#.
|
||||
..##..##.
|
||||
#.#.##.#.
|
||||
|
||||
#...##..#
|
||||
#....#..#
|
||||
..##..###
|
||||
#####.##.
|
||||
#####.##.
|
||||
..##..###
|
||||
#....#..#
|
||||
"
|
||||
)),
|
||||
405
|
||||
);
|
||||
}
|
||||
}
|
|
@ -0,0 +1,125 @@
|
|||
fn main() {
|
||||
println!("{}", part2(include_str!("./input.txt")));
|
||||
}
|
||||
|
||||
fn part2(input: &str) -> usize {
|
||||
input.split("\n\n").map(process_pattern).sum()
|
||||
}
|
||||
|
||||
fn process_pattern(pattern: &str) -> usize {
|
||||
let lines = pattern
|
||||
.lines()
|
||||
.map(|s| s.chars().collect())
|
||||
.collect::<Vec<Vec<_>>>();
|
||||
let width = lines[0].len();
|
||||
(0..lines.len())
|
||||
.find_map(move |i| {
|
||||
let lines = lines.clone();
|
||||
(0..width).find_map(move |j| {
|
||||
let mut local_lines = lines
|
||||
.clone()
|
||||
.iter()
|
||||
.map(|row| row.to_vec())
|
||||
.collect::<Vec<Vec<_>>>();
|
||||
let smudge = local_lines.get_mut(i).unwrap().get_mut(j).unwrap();
|
||||
*smudge = if smudge == &'#' { '.' } else { '#' };
|
||||
|
||||
let mut sum = check_for_reflection(local_lines.clone(), i) * 100;
|
||||
if sum > 0 {
|
||||
return Some(sum);
|
||||
}
|
||||
|
||||
let columns = (0..width)
|
||||
.map(|i| local_lines.iter().map(|row| row[i]).collect::<Vec<char>>())
|
||||
.collect();
|
||||
sum += check_for_reflection(columns, j);
|
||||
|
||||
if sum > 0 {
|
||||
Some(sum)
|
||||
} else {
|
||||
None
|
||||
}
|
||||
})
|
||||
})
|
||||
.expect("no reflection found")
|
||||
}
|
||||
|
||||
fn check_for_reflection(pattern: Vec<Vec<char>>, must_include: usize) -> usize {
|
||||
(1..pattern.len())
|
||||
.find(|i| {
|
||||
let a = &pattern[0..*i];
|
||||
let b = &pattern[*i..];
|
||||
|
||||
let diff = must_include.abs_diff(*i);
|
||||
|
||||
let zipped = a.iter().rev().zip(b).collect::<Vec<_>>();
|
||||
|
||||
zipped.len() > diff && zipped.iter().all(|(a, b)| a == b)
|
||||
})
|
||||
.unwrap_or(0)
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
use indoc::indoc;
|
||||
|
||||
#[test]
|
||||
fn test_part2() {
|
||||
assert_eq!(
|
||||
part2(indoc!(
|
||||
"
|
||||
#.##..##.
|
||||
..#.##.#.
|
||||
##......#
|
||||
##......#
|
||||
..#.##.#.
|
||||
..##..##.
|
||||
#.#.##.#.
|
||||
|
||||
#...##..#
|
||||
#....#..#
|
||||
..##..###
|
||||
#####.##.
|
||||
#####.##.
|
||||
..##..###
|
||||
#....#..#
|
||||
"
|
||||
)),
|
||||
400
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_pattern_part2() {
|
||||
assert_eq!(
|
||||
process_pattern(indoc!(
|
||||
"
|
||||
#.##..##.
|
||||
..#.##.#.
|
||||
##......#
|
||||
##......#
|
||||
..#.##.#.
|
||||
..##..##.
|
||||
#.#.##.#.
|
||||
"
|
||||
)),
|
||||
300
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
process_pattern(indoc!(
|
||||
"
|
||||
#...##..#
|
||||
#....#..#
|
||||
..##..###
|
||||
#####.##.
|
||||
#####.##.
|
||||
..##..###
|
||||
#....#..#
|
||||
"
|
||||
)),
|
||||
100
|
||||
);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue