結果
問題 |
No.1477 Lamps on Graph
|
ユーザー |
|
提出日時 | 2021-05-02 03:45:28 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
MLE
|
実行時間 | - |
コード長 | 884 bytes |
コンパイル時間 | 91 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 817,944 KB |
最終ジャッジ日時 | 2024-07-20 12:08:04 |
合計ジャッジ時間 | 3,826 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 10 MLE * 1 -- * 27 |
ソースコード
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])