• 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    미해결

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

22.09.19 23:39 작성 조회수 173

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

깨위님의 프로필

깨위

2023.01.22

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

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

안녕하세요^^

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