Compare commits

...

6 Commits

Author SHA1 Message Date
Johannes Schaefer
6f2e046080 day14 both parts 2018-12-17 17:45:35 +01:00
Johannes Schaefer
6f9ca4dfb6 2018-12-17 11:06:12 +01:00
Johannes Schaefer
2fa6c40f33 day12 part 1 2018-12-14 14:09:57 +01:00
Johannes Schaefer
54103e8fa6 day11 part2 fast 2018-12-11 16:02:22 +01:00
Johannes Schaefer
fc328d82af day11 part2 2018-12-11 11:37:32 +01:00
Johannes Schaefer
267dfb8068 day11 part 1 2018-12-11 11:25:57 +01:00
6 changed files with 272 additions and 3 deletions

34
input/day12.txt Normal file
View File

@@ -0,0 +1,34 @@
initial state: ..##.#######...##.###...#..#.#.#..#.##.#.##....####..........#..#.######..####.#.#..###.##..##..#..#
#..#. => .
..#.. => .
..#.# => #
##.#. => .
.#... => #
#.... => .
##### => #
.#.## => .
#.#.. => .
#.### => #
.##.. => #
##... => .
#...# => #
####. => #
#.#.# => .
#..## => .
.#### => .
...## => .
..### => #
.#..# => .
##..# => #
.#.#. => .
..##. => .
###.. => .
###.# => #
#.##. => #
..... => .
.##.# => #
....# => .
##.## => #
...#. => #
.###. => .

View File

@@ -1,4 +1,4 @@
fn main() {
aoc_2018::tasks::day13::task1();
// aoc_2018::tasks::day09::task2();
// aoc_2018::tasks::day14::task1();
aoc_2018::tasks::day14::task2();
}

124
src/tasks/day11.rs Normal file
View File

@@ -0,0 +1,124 @@
pub fn task1() {
let square_size = 3;
let serial = 6392;
let result = (1..=300 - square_size)
.flat_map(|x: i32| (1..=300 - square_size).map(move |y: i32| (x, y)))
.map(|(x, y)| {
let power: i32 = (x..x + square_size)
.map(|x| {
(y..y + square_size)
.map(move |y| fuel_level(x, y, serial))
.sum::<i32>()
})
.sum();
(x, y, power)
})
.max_by_key(|(_, _, value)| *value);
println!("{:?}", result);
}
pub fn task2() {
let serial = 6392;
let mut values: Vec<Vec<i32>> = Vec::with_capacity(301);
for x in 0..=300 {
let mut v: Vec<i32> = Vec::with_capacity(301);
for y in 0..=300 {
v.push(fuel_level(x, y, serial));
}
values.push(v);
}
let values = &values;
let result = (1..300)
.map(|square_size| {
let result = (1..=300 - square_size)
.flat_map(|x: i32| (1..=300 - square_size).map(move |y: i32| (x, y)))
.map(|(x, y)| {
let power: i32 = (x..x + square_size)
.map(|x| {
(y..y + square_size)
.map(move |y| values[x as usize][y as usize])
.sum::<i32>()
})
.sum();
(x, y, power)
})
.max_by_key(|(_, _, value)| *value)
.unwrap();
(result.0, result.1, result.2, square_size)
})
.max_by_key(|result| result.2);
println!("{:?}", result);
}
pub fn task2_fast() {
let serial = 6392;
let mut cache: Vec<Vec<i32>> = Vec::with_capacity(301);
for x in 0 as usize..=300 {
let mut v: Vec<i32> = Vec::with_capacity(301);
for y in 0 as usize..=300 {
if x == 0 || y == 0 {
v.push(0);
} else {
v.push(
fuel_level(x as i32, y as i32, serial) + v[v.len() - 1] + cache[x - 1][y]
- cache[x - 1][y - 1],
)
}
}
cache.push(v);
}
let values = &cache;
for x in 0 as usize..=300 {
for y in 0 as usize..=300 {
if x != 0 && y != 0 {
let cached = area_sum(&values, x, y, 1);
let calc = fuel_level(x as i32, y as i32, serial);
//println!("{},{}: {} ({})", x, y, values[x][y], calc);
assert_eq!(calc, cached);
}
}
}
let result = (1..=300)
.map(|square_size| {
let result = (1..=301 - square_size)
.flat_map(|x: usize| (1..=301 - square_size).map(move |y: usize| (x, y)))
.map(|(x, y)| (x, y, area_sum(&values, x, y, square_size)))
.max_by_key(|(_, _, value)| *value)
.unwrap();
(result.0, result.1, result.2, square_size)
})
.max_by_key(|result| result.2);
println!("{:?}", result);
}
fn area_sum(values: &Vec<Vec<i32>>, x: usize, y: usize, length: usize) -> i32 {
values[x + length - 1][y + length - 1] + values[x - 1][y - 1]
- values[x - 1][y + length - 1]
- values[x + length - 1][y - 1]
}
fn fuel_level(x: i32, y: i32, serial: i32) -> i32 {
let rack_id = x + 10;
let mut power = rack_id * y;
power += serial;
power *= rack_id;
power = power / 100 % 10;
power = power - 5;
power
}
mod test {
use super::fuel_level;
#[test]
fn name() {
assert_eq!(fuel_level(3, 5, 8), 4);
assert_eq!(fuel_level(122, 79, 57), -5);
assert_eq!(fuel_level(217, 196, 39), 0);
assert_eq!(fuel_level(101, 153, 71), 4);
}
}

54
src/tasks/day12.rs Normal file
View File

@@ -0,0 +1,54 @@
use crate::utils;
use std::collections::HashMap;
use std::ops::Add;
pub fn task1() {
let input = utils::read_file("input/day12.txt");
let mut input = input.lines();
let num_generations = 20;
let mut state: Vec<char> = "."
.repeat(num_generations)
.add(&input.next().unwrap()[15..])
.add(&".".repeat(num_generations + 2))
.chars()
.collect();
let mut transformations: HashMap<String, char> = HashMap::new();
input.next();
for line in input {
let key = line.split(" => ").nth(0).unwrap();
transformations.insert(key.to_string(), line.chars().last().unwrap());
}
for _ in 0..num_generations {
println!("{}", state.iter().collect::<String>());
let mut new_state = state.clone();
for (i, c) in new_state[2..state.len() - 2].iter_mut().enumerate() {
let next = transformations.get(&state[i..i + 5].iter().collect::<String>());
if let Some(cc) = next {
*c = *cc;
} else {
*c = '.';
}
}
state = new_state;
}
println!("{}", state.iter().collect::<String>());
let sum: isize = state
.iter()
.enumerate()
.map(|(i, c)| {
if *c == '#' {
i as isize - (num_generations as isize)
} else {
0
}
})
.sum();
println!("Result: {}", sum);
}

55
src/tasks/day14.rs Normal file
View File

@@ -0,0 +1,55 @@
pub fn task1() {
let input: usize = 509671;
let mut scores = vec![3, 7];
let mut recipes = vec![0, 1];
while scores.len() < input + 10 {
let mut score: usize = recipes.iter().map(|recipe| scores[*recipe]).sum();
if score >= 10 {
scores.push(1);
score -= 10;
}
scores.push(score);
for recipe in recipes.iter_mut() {
*recipe = (*recipe + 1 + scores[*recipe]) % scores.len();
}
}
let result = scores[input..input + 10]
.iter()
.map(|s| s.to_string())
.collect::<String>();
println!("Last 10 for {}: {}", input, result);
}
pub fn task2() {
let input = vec![5, 0, 9, 6, 7, 1];
let mut scores = vec![3, 7];
let mut recipes = vec![0, 1];
while scores.len() < 7
|| scores[scores.len() - 6..] != input[..]
&& scores[scores.len() - 7..scores.len() - 1] != input[..]
{
let mut score: usize = recipes.iter().map(|recipe| scores[*recipe]).sum();
if score >= 10 {
scores.push(1);
score -= 10;
}
scores.push(score);
for recipe in recipes.iter_mut() {
*recipe = (*recipe + 1 + scores[*recipe]) % scores.len();
}
}
if scores[scores.len() - 6..] != input[..] {
println!("{}", scores.len() - 7)
} else {
println!("{}", scores.len() - 8)
}
// 20227890 too high
}

View File

@@ -8,5 +8,7 @@ pub mod day07;
pub mod day08;
pub mod day09;
pub mod day10;
pub mod day11;
pub mod day12;
pub mod day13;
pub mod day14;