Day 6: Guard Gallivant

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

  • @[email protected]OPM
    link
    fedilink
    21 month ago

    How did you detect loops? I just ran for 100000 steps to see if I escaped, got my time down to 3s by doing only 10000 steps.

    • @Leavingoldhabits
      link
      21 month ago

      Not who you asked but: I save coordinates and direction into a vector each time the guard faces a #. Also every time the guard faces a #, I check if the position exists in the vector, if true, it’s an infinite loop. 78ms rust aolution.

      • @[email protected]OPM
        link
        fedilink
        11 month ago

        That’s probably quite optimal, compared with checking every state in the path, or running off a fixed number of steps

    • @TunaCowboy
      link
      2
      edit-2
      1 month ago

      I added each visited position/direction to a set, and when a ‘state’ is reached again you have entered a loop:

      v = set()
      while t[g.r][g.c] != 'X':
          state = (g.r, g.c, g.d)
          if state in v:
              acc += 1
              break
          v.add(state)
          g.move(t)
      

      You can view my full solution here.