Submission #69756513
Source Code Expand
"""
<方針>
- `-1` がワイルドカードを表しており、それ以外が重複してないことを確認すれば存在するかはわかりそう。
- `P` を構築するには、存在していなかったものを順番に当てていけば良さそう。
"""
# 入力
N = int(input())
A = list(map(int, input().split()))
# 重複の有無を確認する。(0-indexed管理)
exists = [False]*(N)
for i in range(N):
a = A[i]
# -1は無視
if(a == -1):
continue
# 重複がある時は終了
if(exists[a - 1]):
print("No")
exit()
# 存在を記憶する
exists[a - 1] = True
# 存在しなかったものだけを
wild_candidates = []
for i in range(N):
if not (exists[i]):
wild_candidates.append(i+1)
# Pの構築
P = []
# ワイルドカードを順番に消費していくもの
current_wild = 0
for i in range(N):
# ワイルドカードの消費
if(A[i] == -1):
P.append(wild_candidates[current_wild])
# 次のワイルドカードをみる
current_wild += 1
else:
# 既存のAを使う
P.append(A[i])
# 出力
print("Yes")
print(*P)
Submission Info
| Submission Time | |
|---|---|
| Task | B - Find Permutation 2 |
| User | mattsunkun |
| Language | Python (PyPy 3.10-v7.3.12) |
| Score | 200 |
| Code Size | 1173 Byte |
| Status | AC |
| Exec Time | 65 ms |
| Memory | 76756 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 200 / 200 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt |
| All | 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_Yes_00.txt, 01_Yes_01.txt, 01_Yes_02.txt, 01_Yes_03.txt, 01_Yes_04.txt, 01_Yes_05.txt, 01_Yes_06.txt, 01_Yes_07.txt, 01_Yes_08.txt, 01_Yes_09.txt, 01_Yes_10.txt, 01_Yes_11.txt, 01_Yes_12.txt, 01_Yes_13.txt, 01_Yes_14.txt, 01_Yes_15.txt, 01_Yes_16.txt, 01_Yes_17.txt, 01_Yes_18.txt, 01_Yes_19.txt, 01_Yes_20.txt, 02_No_00.txt, 02_No_01.txt, 02_No_02.txt, 02_No_03.txt, 02_No_04.txt, 02_No_05.txt, 02_No_06.txt, 02_No_07.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| 00_sample_00.txt | AC | 61 ms | 76372 KiB |
| 00_sample_01.txt | AC | 55 ms | 76588 KiB |
| 00_sample_02.txt | AC | 61 ms | 76252 KiB |
| 01_Yes_00.txt | AC | 56 ms | 76576 KiB |
| 01_Yes_01.txt | AC | 55 ms | 76412 KiB |
| 01_Yes_02.txt | AC | 55 ms | 76596 KiB |
| 01_Yes_03.txt | AC | 64 ms | 76544 KiB |
| 01_Yes_04.txt | AC | 56 ms | 76756 KiB |
| 01_Yes_05.txt | AC | 56 ms | 76384 KiB |
| 01_Yes_06.txt | AC | 57 ms | 76304 KiB |
| 01_Yes_07.txt | AC | 56 ms | 76536 KiB |
| 01_Yes_08.txt | AC | 62 ms | 76564 KiB |
| 01_Yes_09.txt | AC | 55 ms | 76332 KiB |
| 01_Yes_10.txt | AC | 54 ms | 76408 KiB |
| 01_Yes_11.txt | AC | 59 ms | 76688 KiB |
| 01_Yes_12.txt | AC | 55 ms | 76600 KiB |
| 01_Yes_13.txt | AC | 64 ms | 76200 KiB |
| 01_Yes_14.txt | AC | 62 ms | 76720 KiB |
| 01_Yes_15.txt | AC | 60 ms | 76396 KiB |
| 01_Yes_16.txt | AC | 55 ms | 76352 KiB |
| 01_Yes_17.txt | AC | 61 ms | 76288 KiB |
| 01_Yes_18.txt | AC | 57 ms | 76120 KiB |
| 01_Yes_19.txt | AC | 55 ms | 76396 KiB |
| 01_Yes_20.txt | AC | 65 ms | 76428 KiB |
| 02_No_00.txt | AC | 58 ms | 76432 KiB |
| 02_No_01.txt | AC | 58 ms | 76192 KiB |
| 02_No_02.txt | AC | 55 ms | 76404 KiB |
| 02_No_03.txt | AC | 54 ms | 76560 KiB |
| 02_No_04.txt | AC | 62 ms | 76176 KiB |
| 02_No_05.txt | AC | 58 ms | 76396 KiB |
| 02_No_06.txt | AC | 55 ms | 76228 KiB |
| 02_No_07.txt | AC | 58 ms | 76564 KiB |