結果

問題 No.1477 Lamps on Graph
ユーザー Super Solenoid
提出日時 2021-05-02 04:36:58
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 912 ms / 2,000 ms
コード長 735 bytes
コンパイル時間 124 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 62,252 KB
最終ジャッジ日時 2024-07-20 13:05:18
合計ジャッジ時間 17,649 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 38
権限があれば一括ダウンロードができます

ソースコード

diff #

N, M = map(int, input().split())
A = [int(s) for s in input().split()]
V = [[int(i)-1 for i in input().split()] for m in range(M)]

K = int(input())
B = [int(s) for s in input().split()]

X = [0]*N

for i in range(N):
    X[i] = []

L = [0]*N

for i in range(M):
    a = V[i][0]
    b = V[i][1]
    if A[a] < A[b]:
        X[a].append(b)
    else:
        if A[b] < A[a]:
            X[b].append(a)

for j in range(len(B)):
    L[B[j]-1] = 1

A, C = (list(t) for t in zip(*sorted(zip(A, list(range(N))))))

Y = []

for i in range(N):
    if L[C[i]]%2 == 1:
        L[C[i]] = 0
        Y.append(C[i]+1)
        for j, item in enumerate(X[C[i]]):
            L[item] = (L[item]+1)%2

print(len(Y))
for i in range(len(Y)):
    print(Y[i])
0