[백준/Python] 14503번: 로봇 청소기

2024. 10. 12. 17:00· Koala - 16기/코딩테스트 심화 스터디
목차
  1. 문제
  2. 입력
  3. 풀이

문제

로봇 청소기와 방의 상태가 주어졌을 때, 청소하는 영역의 개수를 구하는 프로그램을 작성하시오.

로봇 청소기가 있는 방은 N × M 크기의 직사각형으로 나타낼 수 있으며, 1 × 1 크기의 정사각형 칸으로 나누어져 있다. 각각의 칸은 벽 또는 빈 칸이다. 청소기는 바라보는 방향이 있으며, 이 방향은 동, 서, 남, 북 중 하나이다. 방의 각 칸은 좌표 (r, c)로 나타낼 수 있고, 가장 북쪽 줄의 가장 서쪽 칸의 좌표가 (0, 0), 가장 남쪽 줄의 가장 동쪽 칸의 좌표가 (N − 1, M − 1)이다. 즉, 좌표 (r, c)는 북쪽에서 (r + 1)번째에 있는 줄의 서쪽에서 (c + 1)번째 칸을 가리킨다. 처음에 빈 칸은 전부 청소되지 않은 상태이다.

로봇 청소기는 다음과 같이 작동한다.

  1. 현재 칸이 아직 청소되지 않은 경우, 현재 칸을 청소한다.
  2. 현재 칸의 주변 4칸 중 청소되지 않은 빈 칸이 없는 경우:
    • 바라보는 방향을 유지한 채로 한 칸 후진할 수 있다면 한 칸 후진하고 1번으로 돌아간다.
    • 바라보는 방향의 뒤쪽 칸이 벽이라 후진할 수 없다면 작동을 멈춘다.
  3. 현재 칸의 주변 4칸 중 청소되지 않은 빈 칸이 있는 경우:
    • 반시계 방향으로 90도 회전한다.
    • 바라보는 방향을 기준으로 앞쪽 칸이 청소되지 않은 빈 칸인 경우 한 칸 전진한다.
    • 1번으로 돌아간다.

입력

첫째 줄에 방의 크기 N과 M이 입력된다. (3 ≤ N, M ≤ 50)

둘째 줄에 처음에 로봇 청소기가 있는 칸의 좌표 (r, c)와 처음에 로봇 청소기가 바라보는 방향 d가 입력된다. d가 0인 경우 북쪽, 1인 경우 동쪽, 2인 경우 남쪽, 3인 경우 서쪽을 바라보고 있는 것이다.

셋째 줄부터 N개의 줄에 각 장소의 상태를 나타내는 N × M개의 값이 한 줄에 M개씩 입력된다. i번째 줄의 j번째 값은 칸 (i, j)의 상태를 나타내며, 이 값이 0인 경우 (i, j)가 청소되지 않은 빈 칸이고, 1인 경우 (i, j)에 벽이 있는 것이다. 방의 가장 북쪽, 가장 남쪽, 가장 서쪽, 가장 동쪽 줄 중 하나 이상에 위치한 모든 칸에는 벽이 있다. 로봇 청소기가 있는 칸은 항상 빈 칸이다.

풀이

문제에 주어진 조건대로 변수를 선언하고 입력 받는다. 이후 문제에서 주어진 로봇 청소기의 동작 원리를 그대로 구현한다.

이 때, dx, dy 테크닉을 이용하여 방향 전환을 구현한다.

dx = [-1, 0, 1, 0]  # 북 동 남 서
dy = [0, 1, 0, -1]  # 북 동 남 서

n, m = map(int, input().split())
r, c, d = map(int, input().split())  # (r, c)에서 시작, d를 바라봄

arr = []
cnt = 0  # 청소하는 영역의 개수

for _ in range(n):
    now = list(map(int, input().split()))
    arr.append(now)

while True:
    if arr[r][c] == 0:  # 1. 현재 칸이 아직 청소되지 않은 경우, 현재 칸을 청소한다.
        cnt += 1
        arr[r][c] = 2
    cleaned = False
    for _ in range(4):  # 4방향 모두 확인
        d = (d + 3) % 4  # 반시계 방향으로 90도 회전
        next_x, next_y = r + dx[d], c + dy[d]
        if arr[next_x][next_y] == 0:  # 청소되지 않은 빈 칸이 있으면
            r, c = next_x, next_y  # 한 칸 전진
            cleaned = True
            break
    if not cleaned:  # 4방향 모두 청소가 되어있거나 벽인 경우
        next_x, next_y = r + dx[(d + 2) % 4], c + dy[(d + 2) % 4]  # 후진할 방향 계산
        if arr[next_x][next_y] == 1:  # 뒤쪽이 벽이라 후진 불가
            print(cnt)
            break
        else:
            r, c = next_x, next_y  # 후진 가능하면 후진

 

저작자표시 (새창열림)

'Koala - 16기 > 코딩테스트 심화 스터디' 카테고리의 다른 글

[백준/Python] 2467번: 용액  (0) 2024.10.13
[BOJ/Python3] 1806번 부분합  (0) 2024.10.13
[백준/C++] 8972번: 미친 아두이노  (0) 2024.10.09
[백준/C++] 16395번: 파스칼의 삼각형  (0) 2024.10.07
[BOJ/Python3] 9095번: 1, 2, 3 더하기  (0) 2024.10.07
  1. 문제
  2. 입력
  3. 풀이
'Koala - 16기/코딩테스트 심화 스터디' 카테고리의 다른 글
  • [백준/Python] 2467번: 용액
  • [BOJ/Python3] 1806번 부분합
  • [백준/C++] 8972번: 미친 아두이노
  • [백준/C++] 16395번: 파스칼의 삼각형
KauKoala
KauKoala
항공대 알고리즘 동아리 Koala 🥰
KauKoala
Koala
KauKoala
전체
오늘
어제
  • 분류 전체보기 (1889)
    • 공지 게시판 (10)
    • 정보 게시판 (8)
    • Codeforce (15)
    • acm-icpc (6)
    • Koala - 1기 (16)
    • Koala - 2기 (111)
      • Programming Contest (1)
      • A반 (20)
      • B반 (39)
      • C반 (22)
      • 기초 강의 (18)
    • Koala - 3기 (10)
      • 기초 스터디 (7)
    • Koala - 4기 (67)
    • Koala - 5기 (144)
      • 기초 알고리즘 스터디 (75)
      • 코딩테스트 준비 스터디 (68)
    • Koala - 6기 (102)
      • 기초 알고리즘 스터디 (75)
      • 코딩테스트 준비 스터디 (25)
      • 모의 테스트 스터디 (1)
    • Koala - 7기 (167)
      • 기초 알고리즘 스터디 (97)
      • 코딩테스트 준비 스터디 (68)
      • 모의 테스트 스터디 (1)
    • Koala - 8기 (44)
      • 기초 알고리즘 스터디 (32)
      • 코딩테스트 준비 스터디 (10)
      • 코드포스 버츄얼 스터디 (0)
      • 프로그래머스 LV2 스터디 (0)
    • Koala - 9기 (205)
      • 기초 알고리즘 스터디 (138)
      • 코딩테스트 준비 스터디 (64)
      • 모의테스트 준비 스터디 (1)
    • Koala - 10기 (117)
      • 기초 알고리즘 스터디 (30)
      • 코딩테스트 준비 스터디 (86)
      • 모의테스트 준비 스터디 (1)
    • Koala - 11기 (151)
      • 기초 알고리즘 스터디 (46)
      • 코딩테스트 준비 스터디 (104)
      • 모의테스트 준비 스터디 (1)
    • Koala - 12기 (86)
      • 기초 알고리즘 스터디 (31)
      • 코딩테스트 준비 스터디 (55)
    • Koala - 13기 (119)
      • 기초 알고리즘 스터디 (52)
      • 코딩테스트 준비 스터디 (67)
    • Koala - 14기 (116)
      • 기초 알고리즘 스터디 (39)
      • 코딩테스트 준비 스터디 (77)
    • Koala - 15기 (138)
      • 기초 알고리즘 스터디 (73)
      • 코딩테스트 준비 스터디 (65)
    • Koala - 16기 (47)
      • 코딩테스트 기초 스터디 (16)
      • 코딩테스트 심화 스터디 (31)
    • Koala - 17기 (62)
      • 코딩테스트 기초 스터디 (15)
      • 코딩테스트 심화 스터디 (47)
    • Koala - 18기 (31)
      • 코딩테스트 기초 스터디 (11)
      • 코딩테스트 심화 스터디 (20)
    • Koala - 19기 (43)
      • 코딩테스트 기초 스터디 (7)
      • 코딩테스트 심화 스터디 (36)
    • Koala - 20기 (0)
      • 코딩테스트 기초 스터디 (0)
      • 코딩테스트 심화 스터디 (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

  • 🐨항공대 알고리즘 학회 Koala 3기 모집
  • 🐨항공대 알고리즘 학회 Koala 2기 모집
  • 소모임 소개

인기 글

태그

  • C++
  • 백준
  • dp
  • BFS
  • 파이썬
  • dfs
  • 백트래킹
  • BOJ

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.3.0
KauKoala
[백준/Python] 14503번: 로봇 청소기
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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