inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

14. 안전영역(DFS)

BFS풀이 시 높이 범위에 대한 의견공유

해결된 질문

302

taehyeong1998

작성한 질문수 3

0

h를 무조건 0~99로 설정하기보다는 미리 높이의 min 값과 max값을 구한 후 min~max 범위로 for 문을 돌려주면 더 효율적인 풀이가 될 것 같습니다.

 

from collections import deque
N = int(input())
graph = [list(map(int,input().split())) for _ in range(N)]


min_rain = 99999999
max_rain = -1

# 높이의 min,max 구해주기
for row in graph:
    min_tmp = min(row)
    max_tmp = max(row)
    if min_tmp < min_rain:
        min_rain = min_tmp
    if max_tmp > max_rain:
        max_rain = max_tmp
        
dr = [1,0,-1,0]
dc = [0,1,0,-1]

ans = 0
for rain in range(min_tmp+1,max_rain):
    visited = [[0 for _ in range(N)] for _ in range(N)]
    cnt = 0
    for rr in range(N):
        for cc in range(N):
            if visited[rr][cc] == 0 and rain < graph[rr][cc] :
                visited[rr][cc] = 1
                q = deque()
                q.append((rr,cc))
                while q:
                    r,c = q.popleft()
                    for i in range(4):
                        nr = r + dr[i]
                        nc = c + dc[i]
                        if 0 <= nr < N and 0 <= nc < N and visited[nr][nc] == 0 and rain < graph[nr][nc]:
                            visited[nr][nc] = 1
                            q.append((nr,nc))
                cnt += 1 
    if cnt > ans:
        ans = cnt
    
print(ans)


코테 준비 같이 해요! python

답변 1

0

김태원

안녕하세요^^

네. 감사합니다.

기존에 윈도우 10으로 잘 써왔는데 윈도우 11로 바꾸고 나서 채점이 안됩니다.

1

80

2

스택에서 ')'을 만나는 경우

0

88

3

문제가 어디있나요?

0

70

2

변수 or 함수명

0

66

1

침몰하는 타이타닉 문제 질문입니다

0

62

1

AA.py 책점 에러

0

60

1

오늘 구매했는데 파이썬 자료구조 궁금한거 있으면 답변이 잘 될까요.

0

112

2

5.동전분배하기 문제 밑에코드도 정답이될까요?

0

110

1

아나그램 비교 코드

0

119

2

AA.PY파일 복사 후 채점 진행할때 오류 발생합니다.

0

161

2

문제 링크가있나여?

0

148

2

채점기 Time Limit Exceeded 오류 문의

1

168

2

동적계획법은 사용하는 문제

0

127

2

제 코드 좀 봐주세요

0

148

1

예외가 존재할 가능성?

0

98

1

3번이 안풀립니다

0

95

0

5번 틀림

0

116

0

오류원인?

0

99

0

리스트 선언

0

108

1

침몰하는 타이타닉(그리디) 문제 질문

0

112

1

알고리즘

0

70

1

코딩테스트

0

93

1

DFS 순서 질문드립니다.

0

130

2

left, right를 사용한 풀이법에 대한 질문입니다

0

91

1