코딩 테스트/백준 강의 기초편

구현)16931.겉넓이 구하기

Carnival7 2021. 8. 24. 19:13

문제 출처 : https://www.acmicpc.net/problem/16931

 

16931번: 겉넓이 구하기

크기가 N×M인 종이가 있고, 종이는 1×1크기의 칸으로 나누어져 있다. 이 종이의 각 칸 위에 1×1×1 크기의 정육면체를 놓아 3차원 도형을 만들었다. 종이의 각 칸에 놓인 정육면체의 개수가 주어

www.acmicpc.net

풀이

# 솔루션 : 3차원으로 생각하자. 2차원에서 dx,dy, nx,ny 를 쓰는 것처럼, 3차원으로 dx,dy,dz, nx,ny,nz를 써서 해결하자

n,m = map(int,input().split())

a=[]

for i in range(n):
    a.append(list(map(int,input().split())))

ans=0

dx=[1,-1,0,0,0,0]
dy=[0,0,1,-1,0,0]
dz=[0,0,0,0,1,-1]

MAX = 102

# 최대 3차원 공간 생성. 칸이 존재하면 True
blocks = [[[False] * MAX for _ in range(MAX)] * 102 for _ in range(MAX)]

# 칸 채우기
for i in range(n):
    for j in range(m):
        # 해당 칸에 쌓여있는 블록의 개수
        block_cnt = a[i][j]
        for k in range(1,block_cnt+1):
            # 블록 쌓기는 1칸부터 시작
            blocks[i+1][j+1][k] = True

# 다른 블록과 접하지 않은 면이 있으면 겉넓이 +1
ans=0
# 블록 쌓기는 1칸부터 시작하니 탐색도 1부터 n+1까지
for x in range(1,n+1):
    for y in range(1,m+1):
        # 해당 칸에 쌓여있는 블록의 개수
        block_cnt = a[x-1][y-1]
        for z in range(1,block_cnt+1):
            # 동서남북위아래 6방향 다 조사
            for d in range(6):
                nx=x+dx[d]
                ny=y+dy[d]
                nz=z+dz[d]
                # 만약 접한 칸이 비어있다면, 겉넓이 +1
                if blocks[nx][ny][nz] == False:
                    ans+=1

print(ans)