add day 1, part 1

This commit is contained in:
Christian Ulrich 2023-12-02 15:24:53 +01:00
parent 70c5cad8b3
commit d5daa3b0c6
No known key found for this signature in database
GPG Key ID: 8241BE099775A097
3 changed files with 1063 additions and 0 deletions

1001
day01/input Normal file

File diff suppressed because it is too large Load Diff

57
day01/part1.rs Normal file
View File

@ -0,0 +1,57 @@
// Copyright 2023 Christian Ulrich
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//
// usage: ./part1 < input
use std::io;
pub struct CalibrationValues {
inner: Vec<Vec<char>>,
}
impl CalibrationValues {
pub fn from_stdin() -> Result<Self, &'static str> {
let mut values = vec![];
for line in io::stdin().lines() {
let digits = line
.unwrap()
.chars()
.filter(|c| c.is_digit(10))
.collect::<Vec<_>>();
if digits.len() > 0 {
values.push(digits);
}
}
Ok(Self { inner: values })
}
pub fn iter(&mut self) -> std::slice::Iter<'_, Vec<char>> {
self.inner.iter()
}
}
fn main() -> Result<(), &'static str> {
let mut values = CalibrationValues::from_stdin()?;
let mut sum = 0;
for digits in values.iter() {
sum += [*digits.first().unwrap(), *digits.last().unwrap()]
.iter()
.collect::<String>()
.parse::<u32>()
.map_err(|_| "cannot parse calibration value")?;
}
println!("{sum}");
Ok(())
}

5
day01/testinput Normal file
View File

@ -0,0 +1,5 @@
1abc2
pqr3stu8vwx
a1b2c3d4e5f
treb7uchet