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
AC × 3
AC × 32
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