Skip Navigation

πŸŽ„ - 2024 DAY 25 SOLUTIONS -πŸŽ„

Day 25: Code Chronicle

Megathread guidelines

  • Keep top level comments as only solutions, if you want to say something other than a solution put it in a new post. (replies to comments can be whatever)
  • You can send code in code blocks by using three backticks, the code, and then three backticks or use something such as https://topaz.github.io/paste/ if you prefer sending it through a URL

FAQ

14 comments
  • Haskell

    A total inability to write code correctly today slowed me down a bit, but I got there in the end. Merry Christmas, everyone <3

     
        
    import Data.Either
    import Data.List
    import Data.List.Split
    
    readInput = partitionEithers . map readEntry . splitOn [""] . lines
      where
        readEntry ls =
          (if head (head ls) == '#' then Left else Right)
            . map (length . head . group)
            $ transpose ls
    
    main = do
      (locks, keys) <- readInput <$> readFile "input25"
      print . length $ filter (and . uncurry (zipWith (<=))) ((,) <$> locks <*> keys)
    
      
  • Dart

    Quick and dirty, and slightly tipsy, code.

    Happy Christmas everyone!

    Thanks to Eric and the team at Advent of Code, to @Ategon@programming.dev and @CameronDev@programming.dev for giving us somewhere to share and discuss our solutions, and to everyone here for the friendly and supportive community.

    See you all next year!

     
        
    import 'package:collection/collection.dart';
    import 'package:more/more.dart';
    
    part1(List<String> lines) {
      var (w, h) = (lines.first.length, lines.indexOf(''));
      var (falsey: keys, truthy: locks) = (lines..insert(0, ''))
          .splitBefore((l) => l.isEmpty)
          .map((g) => [
                for (var x in 0.to(w)) [for (var y in 1.to(h + 1)) g[y][x]]
              ])
          .partition((g) => g[0][0] == '#');
      return keys
          .map((l) => locks.count((k) =>
              0.to(w).every((r) => (l[r] + k[r]).count((e) => e == '#') < 8)))
          .sum;
    }
    
      
  • Uiua

    A Christmas Day treat: a one-liner for you all to decipher!

     
        
    "#####\n.####\n.####\n.####\n.#.#.\n.#...\n.....\n\n#####\n##.##\n.#.##\n...##\n...#.\n...#.\n.....\n\n.....\n#....\n#....\n#...#\n#.#.#\n#.###\n#####\n\n.....\n.....\n#.#..\n###..\n###.#\n###.#\n#####\n\n.....\n.....\n.....\n#....\n#.#..\n#.#.#\n#####"
    /+β™­βŠž(/Γ—<8+)βˆ©Β°β–‘Β°βŠŸ βŠ•(░≑≑/+βŒ•@#)β‰ @#≑(⊒⊒). ⊜(β‰βŠœβˆ˜βŠΈβ‰ @\n)¬±⦷"\n\n". 
    
      
  • Javascript

    Spent 10 minutes debugging my solution until I reread and found out they wanted the number of keys that fit, not the ones that overlapped. Reading comprehension is not it tonight.

     javascript
        
    const [locks, keys] = require('fs').readFileSync(0, 'utf-8').split(/\r?\n\r?\n/g).filter(v => v.length > 0).map(s => s.split(/\r?\n/g).filter(v => v.length > 0)).reduce((acc, s) => {
        const lock = s[0].split('').every(v => v === '#');
        const schema = s.slice(1, -1);
        let rotated = [];
        for (let i = 0; i < schema[0].length; i += 1) {
            for (let j = 0; j < schema.length; j += 1) {
                if (!rotated[i]) rotated[i] = [];
                rotated[i].push(schema[j][i]);
            }
        }
        if (!lock) {
            rotated = rotated.map(v => v.reverse());
        }
        const pinHeights = [];
        for (const row of rotated) {
            const height = row.indexOf('.');
            pinHeights.push(height !== -1 ? height : 5);
        }
        if (lock) {
            acc[0].push(pinHeights);
        } else {
            acc[1].push(pinHeights);
        }
        return acc;
    }, [[],[]]);
    
    let fits = 0;
    for (const lock of locks) {
        for (const key of keys) {
            let overlapped = false;
            for (let i = 0; i < lock.length; i += 1) {
                if ((lock[i] + key[i]) > 5) {
                    overlapped = true;
                }
            }
            if (!overlapped) {
                fits += 1;
            }
        }
    }
    
    console.log('Part One', fits);
    
      
  • Rust

    Nice ending for this year. Lock and key arrays are just added together and all elements must be <= 5. Merry Christmas!

    Also on github

14 comments