Submission details
Task:Abandoned warehouse
Sender:Ranjana
Submission time:2025-09-08 17:27:32 +0300
Language:Python3 (PyPy3)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.05 sdetails
#2ACCEPTED0.05 sdetails
#3ACCEPTED0.05 sdetails
#4ACCEPTED0.05 sdetails
#5ACCEPTED0.05 sdetails
#6ACCEPTED0.27 sdetails
#7ACCEPTED0.48 sdetails
#8ACCEPTED0.41 sdetails
#9ACCEPTED0.74 sdetails
#10ACCEPTED0.84 sdetails
#11ACCEPTED0.10 sdetails
#12ACCEPTED0.07 sdetails
#13ACCEPTED0.83 sdetails
#14ACCEPTED0.05 sdetails
#15ACCEPTED0.05 sdetails
#16ACCEPTED0.92 sdetails

Code

from collections import deque
steps = []
n, m = map(int, input().split())

graph = []
visited = [[False]*m for _ in range(n)]

start_x, start_y = 0, 0

for i in range(n):
    row = list(input().strip())
    graph.append(row)
    steps.append([''] * m)
    for j in range(m):
        if row[j] == 'A':
            start_x, start_y = i, j

def bfs(x,y):
    steps[x][y] = 'X'
    visited[x][y] = True
    q = deque([(x,y)])
    
    directions = [(1, 0, 'D'), (-1, 0, 'U'), (0, 1, 'R'), (0, -1, 'L')]
    
    while q:
        x, y = q.popleft()
        if graph[x][y] == 'B':
            goal = True
            break

        for dx, dy, direction in directions:
            nx, ny = x + dx, y + dy
            if (0 <= nx < n and 0 <= ny < m and 
                not visited[nx][ny] and graph[nx][ny] != '#'):
                visited[nx][ny] = True
                steps[nx][ny] = direction
                q.append((nx, ny))
    else:
        goal = False
        
    if goal:
        #backtrack path with L, R, U, D
        path = []
        while graph[x][y] != 'A':
            path.append(steps[x][y])
            if steps[x][y] == 'D':
                x -= 1
            elif steps[x][y] == 'U':
                x += 1
            elif steps[x][y] == 'R':
                y -= 1
            elif steps[x][y] == 'L':
                y += 1
        print("YES")
        print(len(path))
        print(''.join(path[::-1]))
    else:
        print("NO")


bfs(start_x, start_y)

Test details

Test 1

Verdict: ACCEPTED

input
10 10
##.A######
#.##.##.##
#####..###
.#########
...

correct output
NO

user output
NO

Test 2

Verdict: ACCEPTED

input
10 10
B#..##.#..
#....A##..
#.....#..#
.#......#.
...

correct output
NO

user output
NO

Test 3

Verdict: ACCEPTED

input
10 10
...#..A.#.
....B...##
...#......
..........
...

correct output
YES
3
LLD

user output
YES
3
DLL

Test 4

Verdict: ACCEPTED

input
10 10
.#........
..........
..........
........#.
...

correct output
YES
1
R

user output
YES
1
R

Test 5

Verdict: ACCEPTED

input
10 10
..........
..........
..........
..........
...

correct output
YES
3
RDD

user output
YES
3
DDR

Test 6

Verdict: ACCEPTED

input
1000 1000
##.###..######.#########.###.#...

correct output
NO

user output
NO

Test 7

Verdict: ACCEPTED

input
1000 1000
####.#.###....#.......##.##.#....

correct output
YES
626
LLLDDRDDDDLDLDDLLLLLDDDDLLDLDL...

user output
YES
626
RDDDDDLDDDDLDDDDLLLLLLDDLLLDDL...
Truncated

Test 8

Verdict: ACCEPTED

input
1000 1000
....#.##......#....#......#......

correct output
YES
364
LULULLULLLULLLLLUULLLLUUULLLLL...

user output
YES
364
UUUUUULUUUUUUUUUUULLLUUUULLUUU...
Truncated

Test 9

Verdict: ACCEPTED

input
1000 1000
.................#......#........

correct output
YES
1003
LLLLLLLLLLLLLLLLLLLLLLLLLDLLLL...

user output
YES
1003
DDDDDDDDDDDDDDDDDLDDDDDDDDDDDD...
Truncated

Test 10

Verdict: ACCEPTED

input
1000 1000
.................................

correct output
YES
947
LLLLLLLLLLLLLLLLLLLLLLLLLLLLLL...

user output
YES
947
UUUUUUUUUUUUUUUUUUUUUUUUUUUUUU...
Truncated

Test 11

Verdict: ACCEPTED

input
1000 3
A#B
.#.
.#.
.#.
...

correct output
YES
2000
DDDDDDDDDDDDDDDDDDDDDDDDDDDDDD...

user output
YES
2000
DDDDDDDDDDDDDDDDDDDDDDDDDDDDDD...
Truncated

Test 12

Verdict: ACCEPTED

input
3 1000
A................................

correct output
YES
2000
RRRRRRRRRRRRRRRRRRRRRRRRRRRRRR...

user output
YES
2000
RRRRRRRRRRRRRRRRRRRRRRRRRRRRRR...
Truncated

Test 13

Verdict: ACCEPTED

input
999 999
A#...#...#...#...#...#...#...#...

correct output
YES
499998
DDDDDDDDDDDDDDDDDDDDDDDDDDDDDD...

user output
YES
499998
DDDDDDDDDDDDDDDDDDDDDDDDDDDDDD...
Truncated

Test 14

Verdict: ACCEPTED

input
1 3
A.B

correct output
YES
2
RR

user output
YES
2
RR

Test 15

Verdict: ACCEPTED

input
2 2
##
AB

correct output
YES
1
R

user output
YES
1
R

Test 16

Verdict: ACCEPTED

input
1000 1000
A................................

correct output
YES
1998
RRRRRRRRRRRRRRRRRRRRRRRRRRRRRR...

user output
YES
1998
DDDDDDDDDDDDDDDDDDDDDDDDDDDDDD...
Truncated