강의

멘토링

커뮤니티

Inflearn コミュニティ Q&A

kingaser0927 のプロフィール画像
kingaser0927

投稿した質問数

Pythonアルゴリズム問題プール入門(コーディングテスト対比)

14. 安全領域(DFS)

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

作成

·

354

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)
코테 준비 같이 해요! python

回答 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

codingcamp님의 프로필 이미지
codingcamp
インストラクター

안녕하세요^^

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

kingaser0927 のプロフィール画像
kingaser0927

投稿した質問数

質問する