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

    • @CameronDev@programming.devOPM
      link
      fedilink
      24 months 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@lemmy.world
        link
        fedilink
        24 months 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.

      • @TunaCowboy@lemmy.world
        link
        fedilink
        2
        edit-2
        4 months 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.