[BOJ] 10026 적록색약 Python
2024. 1. 5. 13:35ㆍAlgorithm
from collections import deque
N= int(input())
picture1 = [[] for _ in range (0,N)]
picture2 = [[] for _ in range (0,N)]
for i in range (0,N):
a = list(input())
for j in range (0,N):
if a[j] == "B":
picture1[i].append(a[j])
picture2[i].append(a[j])
else:
picture1[i].append(a[j])
picture2[i].append("G") #R이 G가 된다고 생각하자.
visited1 = [[False for _ in range (0,N)] for _ in range (0,N)]
visited2 = [[False for _ in range (0,N)] for _ in range (0,N)]
dx,dy = [0,0,1,-1],[1,-1,0,0]
cnt1,cnt2 = 0,0
for i in range (0,N):
for j in range (0,N):
if visited1[i][j] == False:
cnt1 += 1
deq = deque()
deq.appendleft([i,j])
while deq:
x = deq.popleft()
visited1[x[0]][x[1]] = True
for k in range (0,4):
a = x[0] + dx[k]
b = x[1] + dy[k]
if 0 <= a < N and 0 <= b < N and visited1[a][b] == False and picture1[a][b] == picture1[x[0]][x[1]]:
deq.appendleft([a,b])
if visited2[i][j] == False:
cnt2 += 1
deq = deque()
deq.appendleft([i,j])
while deq:
x = deq.popleft()
visited2[x[0]][x[1]] = True
for k in range (0,4):
a = x[0] + dx[k]
b = x[1] + dy[k]
if 0 <= a < N and 0 <= b < N and visited2[a][b] == False and picture2[a][b] == picture2[x[0]][x[1]]:
deq.appendleft([a,b])
print(cnt1,cnt2)
그냥 조오금 복잡할 뻔한 BFS / DFS 유형이었다
'Algorithm' 카테고리의 다른 글
[BOJ] 28449 누가 이길까 (1) | 2024.02.07 |
---|---|
[BOJ] 1503 세 수 고르기 Python (0) | 2024.01.10 |
[BOJ] 7569 토마토 Python (0) | 2024.01.05 |
[BOJ] 2312 수 복원하기 Python (1) | 2024.01.04 |
[BOJ] 1334 다음 팰린드롬 수 (0) | 2023.12.31 |