Carnival7
Change Developer
Carnival7
전체 방문자
오늘
어제
  • 분류 전체보기
    • 자바의 정석
    • 프로그래밍 언어별 tools
      • 파이썬
      • 자바
    • 코딩 테스트
      • 백준 강의 기초편
      • 백준 강의 연습편
      • 백준 강의 문제편
      • 삼성 기출
      • 백준 - 일반
      • 카카오 기출
      • 프로그래머스 - 일반
      • 코테 풀이 Tools
    • CS
      • Network
      • 운영체제
      • 알고리즘
      • DB
    • Web_Backend
      • Spring
      • 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술
      • 스프링 핵심 원리 - 기본편
    • DevOps
    • IT 업무 지식
      • 인프라
      • 클라우드
    • 자격증
      • AWS - CLF
      • 정처기 - 실기
    • 생각 정리

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • code deploy
  • 스프링 #AOP
  • 삼성기출 #2023 #상반기
  • DevOps
  • ci/cd
  • 스프링 #인터셉터 #AOP #필터
  • 스프링 부트 무중단 웹 서비스
  • DMZ
  • 슬라이딩 윈도우 #덱
  • 알고리즘 #백준강의기초편 #코딩테스트
  • Github Actions
  • nginx
  • 프로그래머스 #카카오기출 #레벨2
  • 슬라이딩 윈도우
  • 코딩테스트 #삼성기출 #구현 #시뮬레이션
  • 삼성기출 #백준강의문제편

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7
코딩 테스트/백준 강의 기초편

구현)16931.겉넓이 구하기

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

구현)16931.겉넓이 구하기

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)

'코딩 테스트 > 백준 강의 기초편' 카테고리의 다른 글

DP) 1149.RGB 거리  (0) 2022.02.11
구현) 1917.정육면체 전개도  (0) 2021.09.15
구현)2290.LCD Test  (0) 2021.08.23
구현) 14503. 로봇 청소기  (0) 2021.08.20
구현) 14891. 톱니바퀴  (0) 2021.08.19
    '코딩 테스트/백준 강의 기초편' 카테고리의 다른 글
    • DP) 1149.RGB 거리
    • 구현) 1917.정육면체 전개도
    • 구현)2290.LCD Test
    • 구현) 14503. 로봇 청소기
    Carnival7
    Carnival7

    티스토리툴바

    단축키

    내 블로그

    내 블로그 - 관리자 홈 전환
    Q
    Q
    새 글 쓰기
    W
    W

    블로그 게시글

    글 수정 (권한 있는 경우)
    E
    E
    댓글 영역으로 이동
    C
    C

    모든 영역

    이 페이지의 URL 복사
    S
    S
    맨 위로 이동
    T
    T
    티스토리 홈 이동
    H
    H
    단축키 안내
    Shift + /
    ⇧ + /

    * 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.