카테고리 없음
Softeer: 로봇이 지나간 경로
반응형
import sys
import collections
H, W = map(int, sys.stdin.readline().split())
grid = []
num_cell = 0
for _ in range(H):
line = list(sys.stdin.readline())
num_cell += line.count('#')
grid += line,
rows = len(grid)
cols = len(grid[0])
start_pos = []
for y in range(rows):
for x in range(cols):
if grid[y][x] == '#':
start_pos += (y, x),
# 0: N, 1: S, 2: W, 3: E
dirs = [(-1, 0), (1, 0), (0, -1), (0, 1)]
path = {
(0, 1): 'RR',
(0, 2): 'L',
(0, 3): 'R',
(1, 0): 'RR',
(1, 2): 'R',
(1, 3): 'L',
(2, 0): 'R',
(2, 1): 'L',
(2, 3): 'RR',
(3, 0): 'L',
(3, 1): 'R',
(3, 2): 'RR'
}
class MnCtx:
def __init__(self):
self.mn = float('inf')
self.mn_trace = ''
self.msy = -1
self.msx = -1
self.dir = -1
mn_ctx = MnCtx()
def dfs(y, x, cnt, d, trace, visited, mn_ctx):
if cnt >= num_cell:
if len(trace) < mn_ctx.mn:
mn_ctx.mn = len(trace)
mn_ctx.mn_trace = trace
return
for nd in range(4):
ny = y + dirs[nd][0]
nx = x + dirs[nd][1]
dny = y + dirs[nd][0]*2
dnx = x + dirs[nd][1]*2
if (not (0 <= dny < rows and 0 <= dnx < cols)) or \
(ny, nx) in visited or (dny, dnx) in visited:
continue
if grid[ny][nx] != '#' or grid[dny][dnx] != '#':
continue
rotate = ''
if (d, nd) in path:
rotate = path[(d, nd)]
visited.add((ny, nx))
visited.add((dny, dnx))
dfs(dny, dnx, cnt + 2, nd, trace + rotate + 'A', visited, mn_ctx)
visited.discard((ny, nx))
visited.discard((dny, dnx))
for y, x in start_pos:
for d, face in enumerate(['^', 'v', '<', '>']):
visited = set()
visited.add((y, x))
pre_mn = mn_ctx.mn
dfs(y, x, 1, d, face, visited, mn_ctx)
if pre_mn > mn_ctx.mn:
mn_ctx.msy = y
mn_ctx.msx = x
print(mn_ctx.msy + 1, mn_ctx.msx + 1)
print(mn_ctx.mn_trace[:1])
print(mn_ctx.mn_trace[1:])
반응형
댓글