im 준비용으로 풀이
drc = [[0,1],[1,1],[1,0],[1,-1],[0,-1],[-1,-1],[-1,0],[-1,1]]# 63214789
t= int(input())
for tc in range(1,t+1):
n = int(input())
arr = [list(map(int,input().split())) for _ in range(n)]
for i in range(n):
for j in range(n):
if arr[i][j] == 1:
for k in range(8):
c = 1
while c<n:
ni = i + drc[k][0] * c
nj = j + drc[k][1] * c
if ni < 0 or nj < 0 or n <= ni or n <= nj or arr[ni][nj] == 3 or arr[ni][nj] == 1:
break
if arr[ni][nj] == 2:
arr[ni][nj] = 9
c += 1
cnt = 0
for p in range(n):
for q in range(n):
if arr[p][q] == 9:
cnt += 1
print(f'#{tc} {cnt}')
# for b in arr:
# print(b)
'알고리즘 문제풀이' 카테고리의 다른 글
백준 11650.좌표 정렬하기 Python 정렬 실버5 (0) | 2024.03.04 |
---|---|
Swea D2_1970. 쉬운 거스름돈 Python 그리디 (0) | 2024.03.03 |
Swea D3_11671. 기지국 Python (0) | 2024.03.02 |
Swea D4. 반사경 Python (1) | 2024.02.29 |
Swea D4 자기방으로 돌아가기 Python (0) | 2024.02.29 |