Submission #66767661


Source Code Expand

Copy
from collections import deque
import sys
sys.setrecursionlimit(10**7)
N, M = map(int, input().split())
graph = [[] for _ in range(N)]
edges = []
for _ in range(M):
u, v, w = map(int, input().split())
u -= 1; v -= 1
graph[u].append((v, w))
edges.append((u, v, w))
INF = -1
d = [INF] * N
dq = deque([0])
d[0] = 0
while dq:
u = dq.popleft()
for v, w in graph[u]:
if d[v] == INF:
 
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
from collections import deque
import sys
sys.setrecursionlimit(10**7)

N, M = map(int, input().split())
graph = [[] for _ in range(N)]
edges = []
for _ in range(M):
    u, v, w = map(int, input().split())
    u -= 1; v -= 1
    graph[u].append((v, w))
    edges.append((u, v, w))

INF = -1
d = [INF] * N
dq = deque([0])
d[0] = 0
while dq:
    u = dq.popleft()
    for v, w in graph[u]:
        if d[v] == INF:
            d[v] = d[u] ^ w
            dq.append(v)

if d[N-1] == INF:
    print(-1)
    exit()

cycles = []
for u, v, w in edges:
    if d[u] != INF and d[v] != INF:
        x = d[u] ^ w ^ d[v]
        if x:
            cycles.append(x)

def build_basis(xs):
    B = []
    for x in sorted(xs, reverse=True):
        for b in B:
            x = min(x, x ^ b)
        if x:
            B.append(x)
    return B

basis = build_basis(cycles)

res = d[N-1]
for b in basis:
    res = min(res, res ^ b)

print(res)

Submission Info

Submission Time
Task D - XOR Shortest Walk
User kangping
Language Python (PyPy 3.10-v7.3.12)
Score 0
Code Size 970 Byte
Status WA
Exec Time 77 ms
Memory 81232 KiB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 0 / 400
Status
AC × 3
AC × 30
WA × 3
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All hand_01.txt, hand_02.txt, hand_03.txt, hand_04.txt, hand_05.txt, hand_06.txt, hand_07.txt, hand_08.txt, random_01.txt, random_02.txt, random_03.txt, random_04.txt, random_05.txt, random_06.txt, random_07.txt, random_08.txt, random_09.txt, random_10.txt, random_11.txt, random_12.txt, random_13.txt, random_14.txt, random_15.txt, random_16.txt, random_17.txt, random_18.txt, random_19.txt, random_20.txt, random_21.txt, random_22.txt, sample_01.txt, sample_02.txt, sample_03.txt
Case Name Status Exec Time Memory
hand_01.txt AC 65 ms 76944 KiB
hand_02.txt AC 66 ms 76820 KiB
hand_03.txt AC 67 ms 76828 KiB
hand_04.txt AC 66 ms 76660 KiB
hand_05.txt AC 66 ms 77004 KiB
hand_06.txt WA 66 ms 76804 KiB
hand_07.txt WA 66 ms 76752 KiB
hand_08.txt WA 66 ms 76812 KiB
random_01.txt AC 66 ms 76668 KiB
random_02.txt AC 72 ms 76792 KiB
random_03.txt AC 66 ms 76684 KiB
random_04.txt AC 70 ms 76692 KiB
random_05.txt AC 66 ms 76840 KiB
random_06.txt AC 68 ms 76832 KiB
random_07.txt AC 66 ms 76772 KiB
random_08.txt AC 72 ms 76752 KiB
random_09.txt AC 66 ms 76944 KiB
random_10.txt AC 75 ms 81200 KiB
random_11.txt AC 66 ms 76552 KiB
random_12.txt AC 72 ms 76940 KiB
random_13.txt AC 73 ms 81232 KiB
random_14.txt AC 73 ms 81112 KiB
random_15.txt AC 71 ms 80932 KiB
random_16.txt AC 67 ms 76988 KiB
random_17.txt AC 77 ms 80820 KiB
random_18.txt AC 77 ms 80928 KiB
random_19.txt AC 76 ms 80816 KiB
random_20.txt AC 77 ms 81120 KiB
random_21.txt AC 77 ms 80612 KiB
random_22.txt AC 76 ms 80572 KiB
sample_01.txt AC 66 ms 76812 KiB
sample_02.txt AC 65 ms 76748 KiB
sample_03.txt AC 65 ms 76756 KiB


2025-07-09 (Wed)
03:05:50 +09:00