단지번호붙이기 BFS로 문제해결관련
192
유현우
작성한 질문수 5
0
안녕하세요 강사님
chap7에서 단지번호붙이기를 BFS로 해결해보았는데 문제내 입력예제와 출력예제는 제대로 해결이 되지만 채점파일에있는 3,4,5예제에서는 틀리게 답이 나타나는데 코드에서의 원인을 찾지 못해서 질문드립니다.
import sys sys.stdin = open('input.txt','rt') from collections import deque n = int(input()) board = [list(map(int,input())) for _ in range(n)] ch = [[0]*n for _ in range(n)] res = [] dx = [-1, 0, 1, 0] dy = [0, 1, 0, -1] Q = deque() for i in range(n): for j in range(n): if board[i][j] == 1: #for y in board: #print(y) #print() board[i][j] = 0 cnt = 1 Q.append((i,j)) while Q: for j in range(len(Q)): x,y = Q.popleft() for i in range(4): xx = x + dx[i] yy = y + dy[i] if 0<=xx<n and 0<=yy<n and board[xx][yy]==1: board[xx][yy]=0 cnt += 1 Q.append((xx,yy)) res.append(cnt) print(len(res)) res.sort() for x in res: print(x)
코드에 문제가 있는 부분에 대해 알려주시길 부탁드립니다.
답변 1
0
안녕하세요^^
i, j 변수를 하위 블록에서 중복해서 사용하면 안됩니다.
아래와 같이 큐를 돌리시면 됩니다.
while Q:
for _ in range(len(Q)):
x,y = Q.popleft()
for k in range(4):
xx = x + dx[k]
yy = y + dy[k]
if 0<=xx<n and 0<=yy<n and board[xx][yy]==1:
board[xx][yy]=0
cnt += 1
Q.append((xx,yy))
res.append(cnt)
기존에 윈도우 10으로 잘 써왔는데 윈도우 11로 바꾸고 나서 채점이 안됩니다.
1
104
2
스택에서 ')'을 만나는 경우
0
108
3
문제가 어디있나요?
0
86
2
변수 or 함수명
0
76
1
침몰하는 타이타닉 문제 질문입니다
0
71
1
AA.py 책점 에러
0
63
1
오늘 구매했는데 파이썬 자료구조 궁금한거 있으면 답변이 잘 될까요.
0
115
2
5.동전분배하기 문제 밑에코드도 정답이될까요?
0
115
1
아나그램 비교 코드
0
123
2
AA.PY파일 복사 후 채점 진행할때 오류 발생합니다.
0
163
2
문제 링크가있나여?
0
153
2
채점기 Time Limit Exceeded 오류 문의
1
177
2
동적계획법은 사용하는 문제
0
132
2
제 코드 좀 봐주세요
0
154
1
예외가 존재할 가능성?
0
100
1
3번이 안풀립니다
0
98
0
5번 틀림
0
124
0
오류원인?
0
104
0
리스트 선언
0
115
1
침몰하는 타이타닉(그리디) 문제 질문
0
114
1
알고리즘
0
72
1
코딩테스트
0
98
1
DFS 순서 질문드립니다.
0
134
2
left, right를 사용한 풀이법에 대한 질문입니다
0
94
1





