티스토리 뷰

728x90
반응형

문제

https://programmers.co.kr/learn/courses/30/lessons/81302?language=python3 

 

코딩테스트 연습 - 거리두기 확인하기

[["POOOP", "OXXOX", "OPXPX", "OOXOX", "POXXP"], ["POOPX", "OXPXP", "PXXXO", "OXXXO", "OOOPP"], ["PXOPX", "OXOXP", "OXPOX", "OXXOP", "PXPOX"], ["OOOXX", "XOOOX", "OOOXX", "OXOOX", "OOOOO"], ["PXPXP", "XPXPX", "PXPXP", "XPXPX", "PXPXP"]] [1, 0, 1, 1, 1]

programmers.co.kr

 

코드

import collections
def solution(places):
    n = len(places)
    answer = []
    dx, dy = [-1,1,0,0], [0,0,-1,1] # 상하좌우
    d_x, d_y = [-1,-1,1,1], [-1,1,-1,1] # 대각선
    
    for i in places:
        graph = []
        for j in i:
            graph.append(list(j))
            
        queue = collections.deque()
        
        for x in range(len(graph)):
            for y in range(len(graph)):
                if graph[x][y] == 'P':
                    queue.append((x,y))
                    
        def bfs():
            while queue:
                x,y = queue.popleft()
                for k in range(4): # 상하좌우 확인
                    temp_x, temp_y = x,y
                    for _ in range(2): # 상하좌우는 2거리 까지 확인해야함
                        nx = temp_x + dx[k]
                        ny = temp_y + dy[k]
                        if 0 <= nx < n and  0 <= ny < n:
                            if graph[nx][ny] == 'X': # X에 막혀있으면 더이상 갈 필요없어서 break
                                break
                            elif graph[nx][ny] == 'P': # P를 만나면 거리두기를 안지켰으므로 False
                                return False
                            temp_x, temp_y = nx, ny
                        else:
                            break
                            
                for k in range(4): # 대각선 확인
                    n_x = x + d_x[k]
                    n_y = y + d_y[k]
                    if 0 <= n_x < n and  0 <= n_y < n:
                        if graph[n_x][n_y] == 'P': # 대각선이 P일 경우 x,y와 n_x, n_y 근처 두곳이 모두 X여야만 한다.
                            if graph[n_x - d_x[k]][n_y] == 'X' and graph[n_x][n_y  - d_y[k]] == 'X':
                                continue
                            else: # 두곳중 한곳이라도 X가 아니면 False
                                return False
            return True
        check = bfs()
        if check:
            answer.append(1)
        else:
            answer.append(0)
    return answer

 

'P' 에서 시작하여 상하좌우 로는 2거리 까지 확인하여 'P'가 있는지 찾아야 하고

 

대각선으로는 1거리 까지 확인하여 'P'가 있는지 찾아야 한다. 대각선에 'P'가 존재해도 근처 두 곳에 'X'가 있다면 괜찮다.

 

근처 두곳은 대각선 움직인 d_x[k], d_y[k]를 다시 한 좌표씩 빼주면 찾을 수 있다. 

반응형
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31