프로그래머스/lv.2

방문 길이

bingual 2024. 2. 17. 17:49
반응형

 

https://school.programmers.co.kr/learn/courses/30/lessons/49994

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

문제풀이

def solution(dirs):
    n, m = 11, 11
    visited = set()

    def search(y, x):
        d = {"U": (-1, 0), "D": (1, 0), "L": (0, -1), "R": (0, 1)}

        for char in dirs:
            dy, dx = d[char]
            ny, nx = y + dy, x + dx

            if 0 <= ny < n and 0 <= nx < m:
                visited.add((y, x, ny, nx))
                visited.add((ny, nx, y, x))
                y, x = ny, nx

    search(5, 5)
    return len(visited) // 2