Submission #8814457
Source Code Expand
import sys read = sys.stdin.buffer.read readline = sys.stdin.buffer.readline readlines = sys.stdin.buffer.readlines from heapq import heappush, heappop H,W,K = map(int,readline().split()) S = readline().rstrip().decode('utf-8') A = ['#' * (W+2)] A += ['#' + row + '#' for row in read().decode('utf-8').split()] A += ['#' * (W+2)] A = list(''.join(A)) start = A.index('S') goal = A.index('G') A = [x != '#' for x in A] INF = 10 ** 18 S += S wait_U = [INF] * (K+K+1) wait_D = [INF] * (K+K+1) wait_R = [INF] * (K+K+1) wait_L = [INF] * (K+K+1) for n in range(K+K-1,-1,-1): s = S[n] wait_U[n] = 0 if s == 'U' else wait_U[n+1] + 1 wait_D[n] = 0 if s == 'D' else wait_D[n+1] + 1 wait_R[n] = 0 if s == 'R' else wait_R[n+1] + 1 wait_L[n] = 0 if s == 'L' else wait_L[n+1] + 1 H += 2; W += 2 dist = [INF] * (H * W) mask = (1 << 21) - 1 q = [start] dist[start] = 0 while q: x = heappop(q) dv = x >> 21 v = x & mask if dist[v] < dv: continue dvK = dv % K w = v + 1 if A[w]: dw = dv + wait_R[dvK] + 1 if dist[w] >= dw: dist[w] = dw heappush(q,((dw << 21) + w)) w = v - 1 if A[w]: dw = dv + wait_L[dvK] + 1 if dist[w] >= dw: dist[w] = dw heappush(q,((dw << 21) + w)) w = v + W if A[w]: dw = dv + wait_D[dvK] + 1 if dist[w] >= dw: dist[w] = dw heappush(q,((dw << 21) + w)) w = v - W if A[w]: dw = dv + wait_U[dvK] + 1 if dist[w] >= dw: dist[w] = dw heappush(q,((dw << 21) + w)) answer = dist[goal] if answer >= INF: answer = -1 print(answer)
Submission Info
Submission Time | |
---|---|
Task | E - 迷路 |
User | maspy |
Language | PyPy3 (2.4.0) |
Score | 0 |
Code Size | 1746 Byte |
Status | TLE |
Exec Time | 2111 ms |
Memory | 202932 KB |
Judge Result
Set Name | Sample | All | ||||
---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 0 / 500 | ||||
Status | AC |
|
Set Name | Test Cases |
---|---|
Sample | |
All | 01.txt, 02.txt, 03.txt, 04.txt, 05.txt, 06.txt, 07.txt, 08.txt, 09.txt, 10.txt, 11.txt, 12.txt, 13.txt, 14.txt, 15.txt, 16.txt, 17.txt, 18.txt, 19.txt, 20.txt, 21.txt, 22.txt, 23.txt, 24.txt, 25.txt, 26.txt, 27.txt, 28.txt, 29.txt, 30.txt, 31.txt, 32.txt, 33.txt, 34.txt, 35.txt, 36.txt, 37.txt, 38.txt, 39.txt, 40.txt, 41.txt, s1.txt, s2.txt, s3.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
01.txt | AC | 168 ms | 38256 KB |
02.txt | AC | 161 ms | 38256 KB |
03.txt | AC | 161 ms | 38256 KB |
04.txt | AC | 161 ms | 38256 KB |
05.txt | AC | 161 ms | 38256 KB |
06.txt | TLE | 2110 ms | 146996 KB |
07.txt | TLE | 2110 ms | 146996 KB |
08.txt | TLE | 2111 ms | 146996 KB |
09.txt | TLE | 2073 ms | 147124 KB |
10.txt | TLE | 2111 ms | 146996 KB |
11.txt | TLE | 2110 ms | 144308 KB |
12.txt | TLE | 2105 ms | 144308 KB |
13.txt | TLE | 2031 ms | 144308 KB |
14.txt | AC | 1999 ms | 146996 KB |
15.txt | TLE | 2072 ms | 144308 KB |
16.txt | TLE | 2077 ms | 202932 KB |
17.txt | TLE | 2092 ms | 144308 KB |
18.txt | TLE | 2004 ms | 148916 KB |
19.txt | TLE | 2051 ms | 144436 KB |
20.txt | TLE | 2111 ms | 146996 KB |
21.txt | AC | 1680 ms | 144308 KB |
22.txt | AC | 1822 ms | 146996 KB |
23.txt | AC | 1741 ms | 171572 KB |
24.txt | AC | 1649 ms | 146996 KB |
25.txt | AC | 1682 ms | 146996 KB |
26.txt | AC | 1683 ms | 144308 KB |
27.txt | AC | 1633 ms | 144308 KB |
28.txt | AC | 1700 ms | 144436 KB |
29.txt | AC | 1727 ms | 144436 KB |
30.txt | AC | 1641 ms | 146996 KB |
31.txt | AC | 366 ms | 141236 KB |
32.txt | AC | 363 ms | 141108 KB |
33.txt | AC | 365 ms | 144052 KB |
34.txt | AC | 366 ms | 141108 KB |
35.txt | AC | 360 ms | 141108 KB |
36.txt | AC | 360 ms | 141108 KB |
37.txt | AC | 361 ms | 141108 KB |
38.txt | AC | 361 ms | 141236 KB |
39.txt | AC | 362 ms | 141108 KB |
40.txt | AC | 440 ms | 146740 KB |
41.txt | AC | 163 ms | 38256 KB |
s1.txt | AC | 161 ms | 38256 KB |
s2.txt | AC | 163 ms | 38256 KB |
s3.txt | AC | 164 ms | 38256 KB |