Day 3 | Advent of Code 2024

Поділитися
Вставка
  • Опубліковано 12 січ 2025

КОМЕНТАРІ • 26

  • @gauravshah7888
    @gauravshah7888 Місяць тому +4

    Thanks for the video! Also :
    Everyone, please add this case in your test case if possible : ...mul(mul(45,67)... and ...mul(63,mul(12,56)....
    In both this cases, we should consider 45*67 and 12*56.

  • @siddharth-gandhi
    @siddharth-gandhi Місяць тому +17

    wow that adding hashes at end is a great idea!

    • @Errichto
      @Errichto  Місяць тому

      Yup, not worth it for short substrings as comparing 5 characters one by one might be faster than computing a hash in O(1).

  • @Woofer21
    @Woofer21 Місяць тому +5

    Love being able to see other peoples thought processes with these puzzles, personally I used a regex to solve it which ended up being a fairly clean solution.

  • @ChandraShekhar-by3cd
    @ChandraShekhar-by3cd Місяць тому +17

    How are you doing Errichtho, Where had you been, long time no see, no videos, how is life going?

  • @anuraglamsal5142
    @anuraglamsal5142 Місяць тому

    Loving these!

  • @archeryo5218
    @archeryo5218 Місяць тому +2

    Where's day 4!!!!

  • @0x00-V
    @0x00-V Місяць тому

    I'm learning C++. For this problem i used regular expressions

  • @barterjke
    @barterjke Місяць тому

    I understand that regex is not everyone's cup of tea, but why not to use the full power of c++ ?
    std::cin >> s or getline(std::cin, s)? reallocate string is really inefficient. and you could have used strtol for parsing number
    I like how you added hashes to avoid checking for boundaries. It was clever :)

  • @hussein-alemam
    @hussein-alemam Місяць тому

    I get it in exactly 10 lines in python using regexes
    I bet some crazy ppl get it in even less lines

  • @mrlectus
    @mrlectus Місяць тому

    Even I was thinking part 2 was going to be nested mul 😅

  • @praveenpp2929
    @praveenpp2929 Місяць тому

    why not use regex ? but its really very nice to do it with out regex though nice to see this .

    • @Errichto
      @Errichto  Місяць тому +1

      You answered your own question :D
      I agree that it's nice to see various approaches.

  • @codingmickey
    @codingmickey Місяць тому

    Long time no see

  • @legenddxd
    @legenddxd Місяць тому

    First

  • @MemeConnoisseur
    @MemeConnoisseur Місяць тому +1

    regex pattern matching could maybe do it in 10 lines. i am not writing that lol

  • @animesh_chouhan
    @animesh_chouhan Місяць тому +7

    We can actually solve both parts in one line in Python using regex:
    Part 1:
    print(sum(int(x) * int(y) for x, y in re.findall(r"mul\((\d+),(\d+)\)", open('input.txt').read())))
    Part2: A bit complicated due to flag.
    print(sum(int(x) * int(y) for match in re.findall(r"mul\(\d+,\d+\)|do\(\)|don't\(\)", open("input.txt").read()) if (flag := (match == "do()") or (match != "don't()" and globals().get("flag", True))) and match.startswith("mul(") for x, y in [match[4:-1].split(",")]))
    # One-liner un-rolled:
    print(
    sum(
    int(x) * int(y)
    for match in re.findall(
    r"mul\(\d+,\d+\)|do\(\)|don't\(\)", open("input.txt").read()
    )
    if (
    flag := (match == "do()")
    or (match != "don't()" and globals().get("flag", True))
    )
    and match.startswith("mul(")
    for x, y in [match[4:-1].split(",")]
    )
    )

    • @everluck35
      @everluck35 Місяць тому +15

      just no.

    • @Vastaway
      @Vastaway Місяць тому

      i am never going to understand how to use regex lol

    • @MrAdhit
      @MrAdhit Місяць тому

      just... don't use regex for parsing pls

    • @cubernetes
      @cubernetes Місяць тому +2

      @@MrAdhit regex is literally meant for parsing lol, as long as your input is a type 3 language in the chomsky hierarchy

    • @sarcasticdharma
      @sarcasticdharma Місяць тому +1

      For the second part you can reduce complexity somewhat (imo) by instead preprocessing to remove don’t\(\).*(do\(\)|$) then you can just run the same logic from part one.