advent-of-code/aoc2019/src/day01.rs

82 lines
1.8 KiB
Rust
Raw Normal View History

2019-12-01 16:03:34 +01:00
use super::Result;
const INPUT: &str = include_str!("../input/day01.txt");
pub fn run() -> Result<()> {
println!("part 1: {}", part1(INPUT)?);
2019-12-01 16:21:53 +01:00
println!("part 2: {}", part2(INPUT)?);
2019-12-01 16:03:34 +01:00
Ok(())
}
fn fuel_needed(module_weight: u64) -> u64 {
2019-12-01 16:21:53 +01:00
match (module_weight / 3).checked_sub(2) {
Some(f) => f,
None => 0,
}
2019-12-01 16:03:34 +01:00
}
fn part1(input: &str) -> Result<u64> {
input
.lines()
.map(|line| line.parse::<u64>())
.map(|w| match w {
Ok(w) => Ok(fuel_needed(w)),
Err(e) => Err(Box::from(e)),
})
.sum()
}
2019-12-01 16:21:53 +01:00
fn cumulated_fuel_needed(module_weight: u64) -> u64 {
let mut total_fuel = fuel_needed(module_weight);
let mut additional_fuel = fuel_needed(total_fuel);
while additional_fuel != 0 {
total_fuel += additional_fuel;
additional_fuel = fuel_needed(additional_fuel);
}
total_fuel
}
fn part2(input: &str) -> Result<u64> {
input
.lines()
.map(|line| line.parse::<u64>())
.map(|w| match w {
Ok(w) => Ok(cumulated_fuel_needed(w)),
Err(e) => Err(Box::from(e)),
})
.sum()
}
2019-12-01 16:03:34 +01:00
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn part1_provided() {
assert_eq!(fuel_needed(12), 2);
assert_eq!(fuel_needed(14), 2);
assert_eq!(fuel_needed(1969), 654);
assert_eq!(fuel_needed(100756), 33583);
}
#[test]
fn part1_real() {
assert_eq!(part1(INPUT).unwrap(), 3268951);
}
2019-12-01 16:21:53 +01:00
#[test]
fn part2_provided() {
assert_eq!(cumulated_fuel_needed(14), 2);
assert_eq!(cumulated_fuel_needed(1969), 966);
assert_eq!(cumulated_fuel_needed(100756), 50346);
}
#[test]
fn part2_real() {
assert_eq!(part2(INPUT).unwrap(), 4900568);
}
2019-12-01 16:03:34 +01:00
}