인프런 커뮤니티 질문&답변

kingaser님의 프로필 이미지
kingaser

작성한 질문수

파이썬 알고리즘 문제풀이 입문(코딩테스트 대비)

14. 안전영역(DFS)

bfs로 풀어봤는데 뭐가 문제인지 모르겠어요

작성

·

258

0

import sys
from collections import deque
sys.stdin = open("input.txt", 'r')
dx = [-1, 0, 1, 0]
dy = [0, 1, 0, -1]
n = int(input())
board = [list(map(int, input().split())) for _ in range(n)]
res = 0
dq = deque()
for h in range(100):
    ch = [[0]*n for _ in range(n)]
    cnt = 0
    for i in range(n):
        for j in range(n):
            if board[i][j] > h:
                dq.append((i, j))
                ch[i][j] = 1
                while dq:
                    tmp = dq.popleft()
                    for k in range(4):
                        x = tmp[0]+dx[k]
                        y = tmp[1]+dy[k]
                        if 0 <= x < n and 0 <= y < n and ch[x][y] == 0 and board[x][y] > h:
                            ch[x][y] = 1
                            dq.append((x, y))
                cnt += 1
    res = max(res, cnt)
    if cnt == 0:
        break
print(res)

답변 2

0

아래 코드 추가하면 될 것 같은데요?

ch[i][j]==0:
for h in range(100):
    ch = [[0]*n for _ in range(n)]
    cnt = 0
    for i in range(n):
        for j in range(n):
            if board[i][j] > h and ch[i][j]==0:

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

제가 드린 정답코드와 본인 코드를 비교하면서 디버그 해보세요. 스스로 찾는게 공부죠.

kingaser님의 프로필 이미지
kingaser

작성한 질문수

질문하기