Made everything a bit more rustic
This commit is contained in:
parent
7f5b6e03f9
commit
a5f19ecae1
22 changed files with 376 additions and 274 deletions
|
|
@ -1,3 +1,5 @@
|
|||
use crate::common::file::split_lines;
|
||||
|
||||
use super::template::{DayTrait, ResultType};
|
||||
use std::{num::ParseIntError, slice::Iter};
|
||||
use thiserror::Error;
|
||||
|
|
@ -11,18 +13,16 @@ impl DayTrait for Day {
|
|||
DAY_NUMBER
|
||||
}
|
||||
|
||||
fn part1(&self, lines: &[String]) -> anyhow::Result<ResultType> {
|
||||
let instructions = lines
|
||||
.iter()
|
||||
fn part1(&self, lines: &str) -> anyhow::Result<ResultType> {
|
||||
let instructions = split_lines(lines)
|
||||
.map(|line| Instruction::parse(line))
|
||||
.collect::<Result<Vec<_>, _>>()?;
|
||||
let result = CpuCycles::signal_strength(&instructions, &[20, 60, 100, 140, 180, 220]);
|
||||
Ok(ResultType::Integer(result as i64))
|
||||
}
|
||||
|
||||
fn part2(&self, lines: &[String]) -> anyhow::Result<ResultType> {
|
||||
let instructions = lines
|
||||
.iter()
|
||||
fn part2(&self, lines: &str) -> anyhow::Result<ResultType> {
|
||||
let instructions = split_lines(lines)
|
||||
.map(|line| Instruction::parse(line))
|
||||
.collect::<Result<Vec<_>, _>>()?;
|
||||
let result = CpuCycles::draw(&instructions);
|
||||
|
|
@ -128,8 +128,9 @@ impl<'a> Iterator for CpuCycles<'a> {
|
|||
#[cfg(test)]
|
||||
mod test {
|
||||
use super::*;
|
||||
use crate::common::file::read_lines;
|
||||
use crate::common::file::read_string;
|
||||
use anyhow::Result;
|
||||
use itertools::Itertools;
|
||||
|
||||
#[test]
|
||||
fn test_simple() -> Result<()> {
|
||||
|
|
@ -144,7 +145,7 @@ mod test {
|
|||
#[test]
|
||||
fn test_part1() -> Result<()> {
|
||||
let day = Day {};
|
||||
let lines = read_lines(day.get_day_number(), "example01.txt")?;
|
||||
let lines = read_string(day.get_day_number(), "example01.txt")?;
|
||||
let expected = ResultType::Integer(13140);
|
||||
let result = day.part1(&lines)?;
|
||||
assert_eq!(result, expected);
|
||||
|
|
@ -155,8 +156,12 @@ mod test {
|
|||
#[test]
|
||||
fn test_part2() -> Result<()> {
|
||||
let day = Day {};
|
||||
let lines = read_lines(day.get_day_number(), "example01.txt")?;
|
||||
let expected = ResultType::Lines(read_lines(day.get_day_number(), "expected01.txt")?);
|
||||
let lines = read_string(day.get_day_number(), "example01.txt")?;
|
||||
let expected_lines = read_string(day.get_day_number(), "expected01.txt")?;
|
||||
let expected_lines = split_lines(&expected_lines)
|
||||
.map(|s| s.to_owned())
|
||||
.collect_vec();
|
||||
let expected = ResultType::Lines(expected_lines);
|
||||
let result = day.part2(&lines)?;
|
||||
assert_eq!(result, expected);
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue