結果
問題 |
No.2740 Old Maid
|
ユーザー |
![]() |
提出日時 | 2024-12-08 03:52:39 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 590 ms / 2,000 ms |
コード長 | 594 bytes |
コンパイル時間 | 187 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 48,888 KB |
最終ジャッジ日時 | 2024-12-08 03:53:00 |
合計ジャッジ時間 | 17,743 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 62 |
ソースコード
N=int(input()) P=list(map(int,input().split())) P_INV=[-1]*(N+1) for i in range(N): P_INV[P[i]]=i LEFT=[i-1 for i in range(N)] RIGHT=[i+1 for i in range(N)] def use(i): if 0<=LEFT[i]<N: RIGHT[LEFT[i]]=RIGHT[i] if 0<=RIGHT[i]<N: LEFT[RIGHT[i]]=LEFT[i] USE=[0]*N ANS=[] for i in range(1,N+1): if USE[P_INV[i]]==1: continue if RIGHT[P_INV[i]]==N: continue ANS.append(i) USE[P_INV[i]]=1 x=RIGHT[P_INV[i]] ANS.append(P[x]) use(P_INV[i]) use(x) USE[P_INV[i]]=1 USE[x]=1 print(*ANS)