Day 14 done.
This commit is contained in:
parent
c19ee00d71
commit
95885fe72d
|
@ -0,0 +1,100 @@
|
|||
#.....OO..O#.O.#O......#...#...#.O......OOO.....O#...OO##...#..#O..O...........O..#O....O......O..#.
|
||||
#....O#..OO#..O.#O#O......O..#..#.O..#.....###....#.O.....#O#.##..##..............O..OO.#O.##OO.O.O.
|
||||
OO..#.O.O....O..#..##.O..#.O..#O..#..#..#..O.O..#...O#.OO.O.#.....#..#.O..OO.#......#....#.O..#.#.#O
|
||||
....#..#.#.O...O.........#...O...##.....O......#O#O.#O.............O..#O.....O.O.O..O#......#.O.#..O
|
||||
#...O..#..#..#..OO......#.....O.OO...#...OO.O......#O.....OOOOO.##......#.#....OOO#...#.......O.....
|
||||
.O.O...O.#.....O..##......##O#....O.##.#OO#...#OO..O..##...#....#..O.O.##......#..O.O#...........#.#
|
||||
....#....#...OO....#..#.O...O...O.OO#O.OO..O...OO.O....#OO#.#....O....O..#...#.#.##.O...O.O..O..##..
|
||||
...OOO..#..##..O..O.#...#O......OOO....#.#.OO.#.#..#.##O...O.O....##OO..............O#.O..##.O#..OO.
|
||||
##..#.......OOO..O....#.O...O.O......O#..O##.OO###..OO....O......#....##.O.....#O#O...#..O....#.....
|
||||
#..OOO..#.O##O.......O..O....O...#.....#OO..#.......##.O...#....#.#..O.O.#O.....OOOO##..##O#O....O..
|
||||
#.O#..O.#..OO.O.#O.OO#O....OO.....#..O...#..........#....OO..O#O.#OO......#....OO...#....#O.O.O.##..
|
||||
#......#.#.#.##.#O#.O....OO....##.O.#..O..O..O...#O.........#.O#.#..#..#...#....#OO..#OO..#........#
|
||||
...#..O.O.OOO#O#..OO......OO....#..##.....#O.....#.##.OOO#O#..#.....O....#......O.#.#O.O.O..OO.#....
|
||||
.#O..OO#O...#...#O..O#.OO....O..##..#..#...........#..OO#O.#..#...OO...O.#..#..O..##......OO....O..O
|
||||
.O..O#O..#...#O#O#.#......#.#..O...............O..O.O#.O..........##..#.O.....OO#.OO.#....#.####....
|
||||
O..#.O#..O.O.O...#.#O.#.......O....OO.O.#.O.O....#O##.O.......##O..OO#O...##.##O#...........O#.O###.
|
||||
.O..#O..#....#..O#O....OO#....O#........#.#.#...#......#..##...O.......#O.#.#O#.O...#O.#.OO.#.......
|
||||
###O.......#.....O.O..#.#.....O.....#...#.#......#O.O.......##......##......OO.#.O..OO...O#.........
|
||||
..O..O.OO#..OO#O##....O..OO...O.O..OO....#.O...#O.##..#.O........#....#OO#....#...O...O.##.#.#O#OO##
|
||||
....#OO.O.....#.OO.#.#.#.#......OO......O...#.#.#....O..O#......#O.O#...O#.......#..O..O..O.##....OO
|
||||
.OO#OOO.....O.OO...O...#....#OO........OOOOO..O..#...O#..O.....#..O#.#......#O.#..###.O.O..#.O.....#
|
||||
O##.####O.##.OO..#..........O#.O...........#..O..........O...#.....O......#........O.#O.#O#O.O..O...
|
||||
...#.OO..##.....##.O.##...O....O.##.....#.O..O.O.....O.....#....O..#.#..O..O....O....#O..#O..O..O...
|
||||
...O#..OO#O..O...O.....#..#..#.O.O......O#......O.##.OO....O...#....#..O............O...OO#.O..O#.O.
|
||||
O..O..O.#O....O#.##O..#..#.#.O.....####OO...O.##..O#..OO...OO.#O.......##..#.O.....O..O.#O...O..O..#
|
||||
........#O..#O..O..#.#.....#..#...O.......O...#..OO.##.....O...O..O.#.....##.......#O.#O.#O...#O.#..
|
||||
......O...#O#OOO.##.##O..#...O....#O.......OO....#...OO....O...#..O...#O.....OO#O#O##..O..OOO.#..#.O
|
||||
##O..O.O..O.........#O....OO.##O..O..#OO....O.......O#O#.O..O......#....O...#..O#....#.OO#..#....O.#
|
||||
..O....#...........#.O.O.O...#.#....#.#.........O.#..O.#.#..O........#O....##..#O...O.O#...O.#...O.O
|
||||
#....O............#....#..O.O......#....#.#O......#.OOO...#.O..O##...#.#..#...O..O..#..#....O...O...
|
||||
........#..O#.......#O.O.........O.###..#...O#..O.....OO#O...O...OOO.#..........#.O.OO#...O.........
|
||||
.#.....##.#.#O###.O...#.O##O.#..#..OO.....#.....#....#...O........#..##O.#...O.....O........O#.O.O..
|
||||
.O.O##...O..##O...#.........OO#O.#...#O.......O.....O#....O.O.....###...O.#..#....O........OO..O....
|
||||
#.##OO.O.....OOO.#...O......O....#..OO..#O..##...OO.....#.#...O.O#..#O##...OO..#....O#..#.O.#.#..OO.
|
||||
.O........OO.##....O.#.#....#...O.O#..O...##....OO.O....O.##O..#.O....#O....O.....#..O..O.#...OOO..#
|
||||
.OOOO..O#O..##......O##....#OO.#..#...#...OO#.........O.#...#..##..O...O.##.OO##..O.#.......#...#O..
|
||||
.O##......#...#O..OO.O.O.O.......O.#................OO.......O.OO....O......#..O..#....OO#.OO....O#.
|
||||
....#OOO...#..O..#..OO..##...##...#...O.O...#.O..OO#O....#.....##OO...O.O....#.OO.O.#.#O..O.O#.#...#
|
||||
OO...#OO.OO#...#.#....O.#.O...#.....OO..O.....#O..#....O.#.#...............O#..#...###.O.O..#......O
|
||||
#O#.#.....##.O#....#O....O...O.#.OO#.OOO...OO.....OO...O....#.#O....OO..O..#OO#.O...O..#O.##...#....
|
||||
.#.#O#...OO.....#.O##.OO.....#O.#O....O#..O#..O...O....O#.O...#O........#..#OO...#...O.O.#O##....O..
|
||||
.O..#.O#O..O....O...#........O....O........OO..O.#..O..#...O.O.#.O.#.O...O........O..#.#.O#...#...#O
|
||||
....O..O.##O#..O.....OO.O.......##.#....O.....O.OO....#.#..O....#...#O#O.#.#.O..O.#...##.#.O..O.O...
|
||||
#..OO.OO.#...O##O#.O.#.OOO..#O.#.........OO.O..##.#..#..............OO#..##OOOO.O.#..#....#...#....O
|
||||
..O..#.....##.#...OO..O.....OO.....O#.O.##.#...O.#O..#............##....##.....##..#.#.O...O#..OO..O
|
||||
O.#..O.#.........#...OO....OO....#..#...OOO.O..OO.#...OO.......#.#.O..O..O....O.......#O..#O..O..O..
|
||||
#.O#...OO......#..OO#.....#..O....O#....#O...O....#...O...#.O.O..O.O..#O...O.O...OO.#O..#.O.......O#
|
||||
#O........##..O...........O#.........#.O.......O...##..OOO..#...###O....#..#.#.#OO#...#O....O.O...O.
|
||||
#......OO.........O......OO..#..OOO.#......#...O....#.O.#.....OO.#...O..O..........###.O...O......#O
|
||||
####O..OO#....O#...#.O.......O.#...O.....O##....O.O#........#.....#O.#......O.#O....O.#.OO.O.O.#OO.#
|
||||
..#.....#.....O...#..O......##.###...#..O...OO#O...O.#..OO...O#...#.....O..#....#O..OO.O#.....#...##
|
||||
......O#O...O..O...#..O..O.O..#OO.O.#...O##..OOO.#.#.....O....##....#O...O.....OOO..#O.O..O#.OO.O#.#
|
||||
.....O.....O.OO##...OO#....###..#..OO.#O.#.#..#.....#.....O......OO.#.#OO...##......#..O##.#..O#O...
|
||||
...#O..#...O...O.O...#....O.#...O..O.O.......#.#O...O.O...O#.....#.O.#.......OO.#..O..O#.....O......
|
||||
......#.O#.............O...O..O#O...O#.O.#..O..O.O#....#.....O...#...#O.........##...OOO.OO.#.#....O
|
||||
..O..#O...##.O.O......O##...####.#...#..O#....#...O.O.OO........#...O.#.#........#...O......#....O.O
|
||||
..O..#O.OO...O..#...#O....O.....#O......#OO.....#...#..#....O..#..##O..O..##...........O.O##...####.
|
||||
#.OO.O........O.....#O....O..#..##.##.O.....#..........#OO.O.O#O#.....#.O#..O...#O##.....#.#OO......
|
||||
#.....#....O##..O..OO..O...#..O.##.......#..O..O....#.OO..#..#...O..#..O.#.....O.O..#O#.....#.......
|
||||
..O...O..O..#O#...........O.....O....OO.....O..OO...###O##..#.O..O..O..O.#.#OOO#O.O......#.O..#.#...
|
||||
...O#O.O.#..#..........#..OO.###..#O##..O#..OOO....O.#.....##.O##..#...OO...#O....#....OO.O.#.#.#...
|
||||
.O...#..O#O.O.OO....OOO....O#..OO.#O...O.O..#......O.O...##..#..#O.O.#OO...O.O##...........O#O...O..
|
||||
..#..#..##...OO#.....O#O.O#..O...O.##O.##...OOO.O.#O#O..O....O#....O..#...#.O##.....#.O.OOO..#.....#
|
||||
.OO....##O..O#O.O..#.#....OO..O.#.......OOO#.O.......#O.O.O.O.#...O....O.O...##O...O..#OO#.....#...O
|
||||
.......O.O.O#.OO.#.#OO...#.O#..#...O...#...#.#.....O.#O..OO........O#OO##..#.O.O.O#.O..OO#..#.O##...
|
||||
...........O...#..#.OO.....O#.#.#...#O......O..OO..#.#...#.O.O.#.O...O.#.O.O..OO.............#.#O...
|
||||
.#.O#..O.O.O.OOO.##.......#..O.O..O##...O......OOO.......#O#.O.##..#..O...#..#.O.#.O..O...OO#O#.#...
|
||||
.........OO....O..#.......O..O.OOOO#O....O...O..O.O..#OOOO.O.OO.O...O.......#..O....#..O####..O...O.
|
||||
O.O.............#..##O#..O..#..............##.O....#O....OOOO............O.#.#O.O....O.#.......O.O#.
|
||||
....#O.O.#......#....O.O...#O#O#OO#.O.O.....O...O.#...O.OO#...OO#.OO............#....#..O....##.#...
|
||||
#.O..O.O.O.O.............#.#...#....O..#OO.#........O.........O....#..#.O.O.#....#....#..#O..O......
|
||||
.#OO..O..O.O.O#...........#...OO.#.....O.O........O..O.....#.##.OO.O..O..........O...#.O...#..O..#O.
|
||||
...#O#O#.......#.O..O.O.#....#..#..O.O.O..O#..O##........O.O.#....#.......#..O.O..O.#...O..O...#...#
|
||||
OO.O...#..O.#...#O#......##.#O....O...O.......O.O.O......#...........O.O.#O#.........O...O#..O#.#O..
|
||||
O.OO.O.O.O.O..#..OO......OO....OO......OO....#.....O........O.#O.O##.O.O.O.#OO.O....OO..##O#...O....
|
||||
..O..OOO.O...#....O..O#.O...O..O.O#O..OO...#OO.#....#.#.#OO.....#...O..OO#OOO....O..OO.O.O.O#..#.O##
|
||||
O....O............#.O...O...O.O.O.......#..O....#O..#..O#O...#........#....O...#O.##O.#.O.##O....O..
|
||||
.O.O....O..O..O..O..O..O.O.O.#....##...O.O.....O..##.O#.O.O.#.OOO.O........O#OO..OOO.#.#..O.....#O.#
|
||||
OOOO..#.........O...O.....#O.O..#.O.#......O..OO.......#O.............O...#.#.O..#.#.......#.O......
|
||||
.....OO.O...OO.#O...O.#.#.O.#.#..O.O.....O.O.##O..#...O.#...##O.O##...#O#...#O..........O#....##.O..
|
||||
.#..#.....#.O..##O.O...O.#..#.#..###...........O..#.....O#.OOO#..#OO.#.##.O#.....OO..##O.#.O..#O...O
|
||||
#....O...O...O#..O.O......##O...O....##....##.O#.O.....#..##.O#.O#.#...#O.###...#..OO.#O..O.OO....#.
|
||||
..O.OO.#....O.#.OO....O......##.OO.....#.......#.#..O.O.O...O.........#O#..O.O....O....#O.O.O....###
|
||||
.O...#......#OO.#.O#.O.#.O...O....OOO##O#.O##....#.O#..#O#......#.#.........OO....O.#....O.....O....
|
||||
.#..O.O..#O.#....OO....O.O.#.....OO.O#.O#...##O...O#............#.OO.....O...O....#.#O#...#..#.O#.O.
|
||||
.#O.......O.O.#...O.......#..O..#O..O.##..O#.O#....O..O....O.O#...O..OO................#.OO..O.O.#O.
|
||||
.....O.#...O.O.#...#...O.O.O.#......#.O.#.##.........#.#.#O.............#O#.....O.#....O..OO#......#
|
||||
O....O..#.#...#O#.....O.O...#....O..#.O#....O....##.OO..##.....#.O.O...#O...O##....O#OO#...#O#O#.O..
|
||||
..O.#..#O.O...#......#...O.O..O...O......OO#...O...#OO.OO.#.O##..OOO....O..#...OO.O...#O#O..#OOO.#..
|
||||
.##....O.#..O#.#OO..#...O....#O...#..OO................O....O....O#.O.#.OO.O....#...OO.#.O#..#O#...#
|
||||
.....#....#.OO..#O....#.#.....#..##.....O...#.O..O...............#O##....OO.#OO.OO.....O..O......##.
|
||||
.##..##O..#......#O..O...OO....O.#.#OO..#.....O....#O.#.#.#..O...#O.#....#O.O.....#.#O.O..........O.
|
||||
.......O##.O..##..##..O#....O.OOO.OO.#..##O...O#.#......#O.....O..#..#...#...#O..#.#..#..#....#..O..
|
||||
...#.O..O.#....O....O###....O#...#..#O..O...#.#..O.O.OO...O.##......#..##.OO#O..O.......O#.O...O.O..
|
||||
....O.O.O..#O...O.................OO.O.......O.OO.O#.OO..#.O.OOO.O.O....O...OOO....OO....OO#.#...O.O
|
||||
OO.....O.#.##.#O..O.O...#.O.O#...O...O.OO....#..#..........O...##..#.....#.#O...#..O#..###...OO#..#.
|
||||
....#O.....O..O..#.O##.#...###..O...O.O...O#..#.O.#O..#..O.#..O..#....#...#..O..O.O....#..#.....#...
|
||||
#O.......#..O.O..#.....O#O..O..O.O..##..#....O.O#.#..#.O.#.OO..O...#O....O....O#O#..#.#O.O.....#...O
|
||||
.O.###.O..#..#..#.......O.O....#..OO...##..O#O#O#.....O.##O.#..O.O.OO.#.O...OO...OO.O..OO.O..#...O#.
|
||||
.O#OO.#.....O..#.O#.#O.O......O..###.#...#.......O#...#O.#..#..O.#.#......O.O..#O..#...#O..#O.OOO.#.
|
|
@ -0,0 +1,172 @@
|
|||
use std::io;
|
||||
|
||||
fn shift_north(board: &mut Vec<Vec<char>>) {
|
||||
for c in 0..board[0].len() {
|
||||
let mut next = 0;
|
||||
for r in 0..board.len() {
|
||||
if board[r][c] == 'O' {
|
||||
if next != r {
|
||||
board[r][c] = '.';
|
||||
board[next][c] = 'O';
|
||||
}
|
||||
next += 1;
|
||||
}
|
||||
if board[r][c] == '#' {
|
||||
next = r + 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn calc_load(board: &Vec<Vec<char>>) -> usize {
|
||||
let mut sum = 0;
|
||||
|
||||
for (r, row) in board.iter().enumerate() {
|
||||
for space in row {
|
||||
if *space == 'O' {
|
||||
sum += board.len() - r;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
sum
|
||||
}
|
||||
|
||||
pub fn total_load() -> usize {
|
||||
let mut buffer = String::new();
|
||||
|
||||
while io::stdin().read_line(&mut buffer).unwrap() > 0 {}
|
||||
|
||||
let mut board = buffer
|
||||
.trim()
|
||||
.split('\n')
|
||||
.map(|s| s.chars().collect())
|
||||
.collect();
|
||||
|
||||
shift_north(&mut board);
|
||||
|
||||
calc_load(&board)
|
||||
}
|
||||
|
||||
fn shift_west(board: &mut Vec<Vec<char>>) {
|
||||
for r in 0..board.len() {
|
||||
let mut next = 0;
|
||||
for c in 0..board[r].len() {
|
||||
if board[r][c] == 'O' {
|
||||
if next != c {
|
||||
board[r][c] = '.';
|
||||
board[r][next] = 'O';
|
||||
}
|
||||
next += 1;
|
||||
}
|
||||
if board[r][c] == '#' {
|
||||
next = c + 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn shift_south(board: &mut Vec<Vec<char>>) {
|
||||
for c in 0..board[0].len() {
|
||||
let mut next = board.len() - 1;
|
||||
for r in (0..board.len()).rev() {
|
||||
if board[r][c] == 'O' {
|
||||
if next != r {
|
||||
board[r][c] = '.';
|
||||
board[next][c] = 'O';
|
||||
}
|
||||
if next > 0 {
|
||||
next -= 1;
|
||||
}
|
||||
}
|
||||
if board[r][c] == '#' && r > 0 {
|
||||
next = r - 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn shift_east(board: &mut Vec<Vec<char>>) {
|
||||
for r in 0..board.len() {
|
||||
let mut next = board[r].len() - 1;
|
||||
for c in (0..board[r].len()).rev() {
|
||||
if board[r][c] == 'O' {
|
||||
if next != c {
|
||||
board[r][c] = '.';
|
||||
board[r][next] = 'O';
|
||||
}
|
||||
if next > 0 {
|
||||
next -= 1;
|
||||
}
|
||||
}
|
||||
if board[r][c] == '#' && c > 0 {
|
||||
next = c - 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[allow(dead_code)]
|
||||
fn board_to_str(board: &Vec<Vec<char>>) -> String {
|
||||
board
|
||||
.iter()
|
||||
.map(|v| v.iter().collect::<String>())
|
||||
.collect::<Vec<_>>()
|
||||
.join("\n")
|
||||
}
|
||||
|
||||
fn cycle_board(board: &mut Vec<Vec<char>>) {
|
||||
shift_north(board);
|
||||
shift_west(board);
|
||||
shift_south(board);
|
||||
shift_east(board);
|
||||
}
|
||||
|
||||
fn calc_rep_load(board: &mut Vec<Vec<char>>) -> usize {
|
||||
let mut hare = board.clone();
|
||||
let mut iter = 0;
|
||||
loop {
|
||||
// Technically it would be faster to just record the values from cycling a single board and run
|
||||
// loop detection on that but this finishes in 0.5s on my desktop so it's probably fine.
|
||||
cycle_board(board);
|
||||
cycle_board(&mut hare);
|
||||
cycle_board(&mut hare);
|
||||
iter += 1;
|
||||
|
||||
// Technically this cycle detection may not work in all cases because the load
|
||||
// count is not necessarily a unique representation of the game board but hey it works for the
|
||||
// problem input.
|
||||
let board_score = calc_load(board);
|
||||
let hare_score = calc_load(&hare);
|
||||
if board_score == hare_score {
|
||||
let cycle_start = iter;
|
||||
let cycle_value = board_score;
|
||||
loop {
|
||||
cycle_board(board);
|
||||
iter += 1;
|
||||
if calc_load(board) == cycle_value {
|
||||
let period = iter - cycle_start;
|
||||
let remaining_iter = (1_000_000_000 - cycle_start) % period;
|
||||
for _ in 0..remaining_iter {
|
||||
cycle_board(board);
|
||||
}
|
||||
return calc_load(board);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn total_load_many_cycles() -> usize {
|
||||
let mut buffer = String::new();
|
||||
|
||||
while io::stdin().read_line(&mut buffer).unwrap() > 0 {}
|
||||
|
||||
let mut board = buffer
|
||||
.trim()
|
||||
.split('\n')
|
||||
.map(|s| s.chars().collect())
|
||||
.collect();
|
||||
|
||||
calc_rep_load(&mut board)
|
||||
}
|
|
@ -5,6 +5,7 @@ mod day10;
|
|||
mod day11;
|
||||
mod day12;
|
||||
mod day13;
|
||||
mod day14;
|
||||
mod day2;
|
||||
mod day3;
|
||||
mod day4;
|
||||
|
@ -47,6 +48,8 @@ fn main() {
|
|||
"day12b" => println!("Sum: {}", day12::sum_arrangements(true)),
|
||||
"day13a" => println!("Summary: {}", day13::summarize(false)),
|
||||
"day13b" => println!("Summary: {}", day13::summarize(true)),
|
||||
"day14a" => println!("Load: {}", day14::total_load()),
|
||||
"day14b" => println!("Load: {}", day14::total_load_many_cycles()),
|
||||
_ => println!("Unrecognized day: {}", args[1]),
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue