| 20013 | 2025-12-31 01:20:59 | 42 | Városnézés | pypy3 | Accepted 80/80 | 160ms | 34524 KiB |
from sys import stdin,setrecursionlimit
input=stdin.readline
setrecursionlimit(10**6)
def solv():
N,M = map(int,input().split())
P = [0]+list(map(int,input().split()))
G = [set() for i in range(N+1)]
Ginv = [set() for i in range(N+1)]
for i in range(M):
x,y = map(int,input().split())
G[x].add(y)
Ginv[y].add(x)
visited={N}
cur=[N]
while cur:
tmp=set()
for v in cur:
for w in Ginv[v]:
if w not in visited:
tmp.add(w)
visited.add(w)
cur=tmp
if 1 not in visited:
print(-1)
return
#print(visited,Ginv)
for v in visited:
tmp=[]
for w in G[v]:
if w not in visited:
tmp.append(w)
for w in tmp:
G[v].remove(w)
#print(G)
res=[0]*(N+1)
reached=[False]*(N+1)
res[N]=P[N]
reached[N]=True
cur=[N]
def rek(i):
cur=-1
for v in G[i]:
if reached[v]:
cur=max(cur,res[v]+P[i])
else:
rek(v)
cur=max(cur,res[v]+P[i])
reached[i]=True
res[i]=cur
rek(1)
"""
while cur:
tmp=set()
for v in cur:
if reached[v]<len(G[v]):
tmp.add(v)
continue
for w in Ginv[v]:
res[w]=max(res[w],res[v]+P[w])
reached[w]+=1
tmp.add(w)
cur=tmp
"""
print(res[1])
RES=[1]
while RES[-1]!=N:
for v in G[RES[-1]]:
if res[v]+P[RES[-1]]==res[RES[-1]]:
RES.append(v)
break
print(*RES)
solv()
| Subtask | Sum | Test | Verdict | Time | Memory | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Accepted | 46ms | 19692 KiB | ||||
| subtask2 | 20/20 | ||||||
| 2 | Accepted | 43ms | 19792 KiB | ||||
| 3 | Accepted | 39ms | 19864 KiB | ||||
| 4 | Accepted | 39ms | 19856 KiB | ||||
| 5 | Accepted | 68ms | 22708 KiB | ||||
| 6 | Accepted | 67ms | 22656 KiB | ||||
| 7 | Accepted | 64ms | 24500 KiB | ||||
| 8 | Accepted | 72ms | 24284 KiB | ||||
| 9 | Accepted | 43ms | 21212 KiB | ||||
| 10 | Accepted | 116ms | 34208 KiB | ||||
| 11 | Accepted | 45ms | 19820 KiB | ||||
| 12 | Accepted | 46ms | 19832 KiB | ||||
| subtask3 | 25/25 | ||||||
| 13 | Accepted | 43ms | 19804 KiB | ||||
| 14 | Accepted | 39ms | 19684 KiB | ||||
| 15 | Accepted | 39ms | 19676 KiB | ||||
| 16 | Accepted | 48ms | 21076 KiB | ||||
| 17 | Accepted | 45ms | 19684 KiB | ||||
| 18 | Accepted | 43ms | 21204 KiB | ||||
| 19 | Accepted | 39ms | 19932 KiB | ||||
| 20 | Accepted | 45ms | 19816 KiB | ||||
| 21 | Accepted | 39ms | 19936 KiB | ||||
| 22 | Accepted | 71ms | 22120 KiB | ||||
| 23 | Accepted | 54ms | 21580 KiB | ||||
| 24 | Accepted | 68ms | 22748 KiB | ||||
| 25 | Accepted | 59ms | 22236 KiB | ||||
| 26 | Accepted | 65ms | 22268 KiB | ||||
| 27 | Accepted | 71ms | 22592 KiB | ||||
| 28 | Accepted | 123ms | 27248 KiB | ||||
| 29 | Accepted | 83ms | 23516 KiB | ||||
| 30 | Accepted | 142ms | 27780 KiB | ||||
| 31 | Accepted | 101ms | 25364 KiB | ||||
| 32 | Accepted | 96ms | 28020 KiB | ||||
| 33 | Accepted | 68ms | 24284 KiB | ||||
| subtask4 | 20/20 | ||||||
| 34 | Accepted | 39ms | 19832 KiB | ||||
| 35 | Accepted | 43ms | 19852 KiB | ||||
| 36 | Accepted | 43ms | 19876 KiB | ||||
| 37 | Accepted | 39ms | 19916 KiB | ||||
| 38 | Accepted | 50ms | 21068 KiB | ||||
| 39 | Accepted | 41ms | 19900 KiB | ||||
| 40 | Accepted | 48ms | 21288 KiB | ||||
| 41 | Accepted | 41ms | 20144 KiB | ||||
| 42 | Accepted | 46ms | 19988 KiB | ||||
| 43 | Accepted | 46ms | 19960 KiB | ||||
| 44 | Accepted | 43ms | 21124 KiB | ||||
| 45 | Accepted | 39ms | 19672 KiB | ||||
| 46 | Accepted | 50ms | 21112 KiB | ||||
| 47 | Accepted | 48ms | 21124 KiB | ||||
| 48 | Accepted | 48ms | 21148 KiB | ||||
| 49 | Accepted | 45ms | 21068 KiB | ||||
| 50 | Accepted | 39ms | 19712 KiB | ||||
| 51 | Accepted | 39ms | 19896 KiB | ||||
| 52 | Accepted | 43ms | 19732 KiB | ||||
| 53 | Accepted | 43ms | 19888 KiB | ||||
| 54 | Accepted | 45ms | 19684 KiB | ||||
| 55 | Accepted | 41ms | 19872 KiB | ||||
| 56 | Accepted | 43ms | 19756 KiB | ||||
| 57 | Accepted | 37ms | 19916 KiB | ||||
| 58 | Accepted | 41ms | 20156 KiB | ||||
| 59 | Accepted | 45ms | 19936 KiB | ||||
| 60 | Accepted | 43ms | 19688 KiB | ||||
| 61 | Accepted | 39ms | 19684 KiB | ||||
| 62 | Accepted | 45ms | 19984 KiB | ||||
| 63 | Accepted | 45ms | 19732 KiB | ||||
| 64 | Accepted | 39ms | 19928 KiB | ||||
| 65 | Accepted | 39ms | 19692 KiB | ||||
| 66 | Accepted | 39ms | 19940 KiB | ||||
| subtask5 | 15/15 | ||||||
| 67 | Accepted | 39ms | 19832 KiB | ||||
| 68 | Accepted | 43ms | 19792 KiB | ||||
| 69 | Accepted | 39ms | 19864 KiB | ||||
| 70 | Accepted | 39ms | 19856 KiB | ||||
| 71 | Accepted | 68ms | 22708 KiB | ||||
| 72 | Accepted | 67ms | 22656 KiB | ||||
| 73 | Accepted | 64ms | 24500 KiB | ||||
| 74 | Accepted | 72ms | 24284 KiB | ||||
| 75 | Accepted | 43ms | 21212 KiB | ||||
| 76 | Accepted | 116ms | 34208 KiB | ||||
| 77 | Accepted | 45ms | 19820 KiB | ||||
| 78 | Accepted | 46ms | 19832 KiB | ||||
| 79 | Accepted | 43ms | 19804 KiB | ||||
| 80 | Accepted | 39ms | 19684 KiB | ||||
| 81 | Accepted | 39ms | 19676 KiB | ||||
| 82 | Accepted | 48ms | 21076 KiB | ||||
| 83 | Accepted | 45ms | 19684 KiB | ||||
| 84 | Accepted | 43ms | 21204 KiB | ||||
| 85 | Accepted | 39ms | 19932 KiB | ||||
| 86 | Accepted | 45ms | 19816 KiB | ||||
| 87 | Accepted | 39ms | 19936 KiB | ||||
| 88 | Accepted | 71ms | 22120 KiB | ||||
| 89 | Accepted | 54ms | 21580 KiB | ||||
| 90 | Accepted | 68ms | 22748 KiB | ||||
| 91 | Accepted | 59ms | 22236 KiB | ||||
| 92 | Accepted | 65ms | 22268 KiB | ||||
| 93 | Accepted | 71ms | 22592 KiB | ||||
| 94 | Accepted | 123ms | 27248 KiB | ||||
| 95 | Accepted | 83ms | 23516 KiB | ||||
| 96 | Accepted | 142ms | 27780 KiB | ||||
| 97 | Accepted | 101ms | 25364 KiB | ||||
| 98 | Accepted | 96ms | 28020 KiB | ||||
| 99 | Accepted | 68ms | 24284 KiB | ||||
| 100 | Accepted | 43ms | 19852 KiB | ||||
| 101 | Accepted | 43ms | 19876 KiB | ||||
| 102 | Accepted | 39ms | 19916 KiB | ||||
| 103 | Accepted | 50ms | 21068 KiB | ||||
| 104 | Accepted | 41ms | 19900 KiB | ||||
| 105 | Accepted | 48ms | 21288 KiB | ||||
| 106 | Accepted | 41ms | 20144 KiB | ||||
| 107 | Accepted | 46ms | 19988 KiB | ||||
| 108 | Accepted | 46ms | 19960 KiB | ||||
| 109 | Accepted | 43ms | 21124 KiB | ||||
| 110 | Accepted | 39ms | 19672 KiB | ||||
| 111 | Accepted | 50ms | 21112 KiB | ||||
| 112 | Accepted | 48ms | 21124 KiB | ||||
| 113 | Accepted | 48ms | 21148 KiB | ||||
| 114 | Accepted | 45ms | 21068 KiB | ||||
| 115 | Accepted | 39ms | 19712 KiB | ||||
| 116 | Accepted | 39ms | 19896 KiB | ||||
| 117 | Accepted | 43ms | 19732 KiB | ||||
| 118 | Accepted | 43ms | 19888 KiB | ||||
| 119 | Accepted | 45ms | 19684 KiB | ||||
| 120 | Accepted | 41ms | 19872 KiB | ||||
| 121 | Accepted | 43ms | 19756 KiB | ||||
| 122 | Accepted | 37ms | 19916 KiB | ||||
| 123 | Accepted | 41ms | 20156 KiB | ||||
| 124 | Accepted | 45ms | 19936 KiB | ||||
| 125 | Accepted | 43ms | 19688 KiB | ||||
| 126 | Accepted | 39ms | 19684 KiB | ||||
| 127 | Accepted | 45ms | 19984 KiB | ||||
| 128 | Accepted | 45ms | 19732 KiB | ||||
| 129 | Accepted | 39ms | 19928 KiB | ||||
| 130 | Accepted | 39ms | 19692 KiB | ||||
| 131 | Accepted | 39ms | 19940 KiB | ||||
| 132 | Accepted | 59ms | 21980 KiB | ||||
| 133 | Accepted | 50ms | 21416 KiB | ||||
| 134 | Accepted | 57ms | 21940 KiB | ||||
| 135 | Accepted | 59ms | 21648 KiB | ||||
| 136 | Accepted | 71ms | 22144 KiB | ||||
| 137 | Accepted | 61ms | 21844 KiB | ||||
| 138 | Accepted | 52ms | 21992 KiB | ||||
| 139 | Accepted | 57ms | 22520 KiB | ||||
| 140 | Accepted | 74ms | 24280 KiB | ||||
| 141 | Accepted | 59ms | 22672 KiB | ||||
| 142 | Accepted | 71ms | 25820 KiB | ||||
| 143 | Accepted | 148ms | 30172 KiB | ||||
| 144 | Accepted | 71ms | 27092 KiB | ||||
| 145 | Accepted | 112ms | 28384 KiB | ||||
| 146 | Accepted | 90ms | 32672 KiB | ||||
| 147 | Accepted | 160ms | 34524 KiB | ||||
| 148 | Accepted | 138ms | 31156 KiB | ||||
| 149 | Accepted | 104ms | 28308 KiB | ||||