chldkato

백준 14503 로봇 청소기 (파이썬) 본문

백준

백준 14503 로봇 청소기 (파이썬)

chldkato 2020. 4. 17. 23:27

https://www.acmicpc.net/problem/14503

 

14503번: 로봇 청소기

로봇 청소기가 주어졌을 때, 청소하는 영역의 개수를 구하는 프로그램을 작성하시오. 로봇 청소기가 있는 장소는 N×M 크기의 직사각형으로 나타낼 수 있으며, 1×1크기의 정사각형 칸으로 나누어져 있다. 각각의 칸은 벽 또는 빈 칸이다. 청소기는 바라보는 방향이 있으며, 이 방향은 동, 서, 남, 북중 하나이다. 지도의 각 칸은 (r, c)로 나타낼 수 있고, r은 북쪽으로부터 떨어진 칸의 개수, c는 서쪽으로 부터 떨어진 칸의 개수이다. 로봇 청소기는 다음

www.acmicpc.net

1. clean 함수에 현재 좌표와 방향이 입력되면 청소할 수 있는지 확인한다

   청소할 수 있으면 0에서 2로 바꾸고 ans에 1을 더한다

2. 이동 방향을 문제의 조건대로 북동남서 순으로 만들면 현재 방향 + 3을 4로 나눈 나머지가 왼쪽 방향이다

   왼쪽방향이 0이면 clean 함수에 다음 좌표와 방향을 입력한다

3. 4방향 모두 이동할 수 없으면 뒤로 이동할 수 있는지 확인한다

   현재 방향 + 2를 4로 나눈 나머지가 뒤로 이동이다

4. 뒤가 벽이면 바로 종료하고 이동할 수 있으면 다음 좌표와 방향을 입력한다

   이 때 방향은 유지한 채로 뒤로 이동한 것이기 때문에 nd가 아니라 d를 입력한다

5. 그동안 기록한 청소 회수를 출력한다

import sys

input = sys.stdin.readline
dx = [-1, 0, 1, 0]
dy = [0, 1, 0, -1]

def clean(x, y, d):
    global ans
    if a[x][y] == 0:
        a[x][y] = 2
        ans += 1
    for _ in range(4):
        nd = (d + 3) % 4
        nx = x + dx[nd]
        ny = y + dy[nd]
        if a[nx][ny] == 0:
            clean(nx, ny, nd)
            return
        d = nd
    nd = (d + 2) % 4
    nx = x + dx[nd]
    ny = y + dy[nd]
    if a[nx][ny] == 1:
        return
    clean(nx, ny, d)


n, m = map(int, input().split())
x, y, d = map(int, input().split())
a = [list(map(int, input().split())) for _ in range(n)]

ans = 0
clean(x, y, d)
print(ans)

Comments