結果

問題 No.1477 Lamps on Graph
コンテスト
ユーザー Super Solenoid
提出日時 2021-05-02 03:45:28
言語 Python3
(3.14.3 + numpy 2.4.4 + scipy 1.17.1)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
MLE  
実行時間 -
コード長 884 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 342 ms
コンパイル使用メモリ 20,700 KB
実行使用メモリ 2,617,072 KB
最終ジャッジ日時 2026-04-02 23:35:24
合計ジャッジ時間 4,174 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 10 MLE * 2 -- * 26
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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] = [0]*N

L = [0]*N

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

for i in range(K):
    L[B[i]-1] = 1

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

Y = [0]*N
D = 0

S = 0

del A, B, V, K
while sum(L) > 0:
    if D == N:
        break
    E = C[D]
    if L[E] == 0:
        D += 1
    else:
        L[E] = 0
        Y[S]=E+1
        for i in range(N):
            if X[E][i] == 1:
                L[i] = (L[i]+1)%2
        D += 1
        S += 1

if D == N+1:
    print(-1)
else:
    print(S)
    for i in range(S):
        print(Y[i])
0