結果

問題 No.2301 Namorientation
ユーザー timitimi
提出日時 2023-05-13 18:18:49
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 914 ms / 3,000 ms
コード長 1,376 bytes
コンパイル時間 162 ms
コンパイル使用メモリ 82,176 KB
実行使用メモリ 225,648 KB
最終ジャッジ日時 2024-11-29 10:05:19
合計ジャッジ時間 22,672 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 45 ms
53,632 KB
testcase_01 AC 47 ms
53,888 KB
testcase_02 AC 46 ms
54,144 KB
testcase_03 AC 46 ms
54,016 KB
testcase_04 AC 44 ms
54,016 KB
testcase_05 AC 44 ms
54,400 KB
testcase_06 AC 48 ms
54,272 KB
testcase_07 AC 45 ms
53,888 KB
testcase_08 AC 44 ms
54,400 KB
testcase_09 AC 44 ms
53,816 KB
testcase_10 AC 45 ms
53,888 KB
testcase_11 AC 44 ms
53,952 KB
testcase_12 AC 563 ms
161,080 KB
testcase_13 AC 511 ms
150,236 KB
testcase_14 AC 897 ms
217,340 KB
testcase_15 AC 615 ms
168,656 KB
testcase_16 AC 768 ms
200,096 KB
testcase_17 AC 571 ms
163,244 KB
testcase_18 AC 798 ms
203,288 KB
testcase_19 AC 490 ms
146,760 KB
testcase_20 AC 866 ms
198,004 KB
testcase_21 AC 599 ms
166,912 KB
testcase_22 AC 453 ms
207,620 KB
testcase_23 AC 453 ms
208,660 KB
testcase_24 AC 395 ms
184,860 KB
testcase_25 AC 398 ms
183,988 KB
testcase_26 AC 496 ms
225,648 KB
testcase_27 AC 898 ms
218,264 KB
testcase_28 AC 887 ms
218,396 KB
testcase_29 AC 893 ms
217,500 KB
testcase_30 AC 914 ms
218,276 KB
testcase_31 AC 871 ms
217,516 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

N=int(input())
D=[0]*N;DD=[[] for _ in range(N)]
A=[];B=[]
for i in range(N):
  u,v=map(int,input().split())
  u-=1;v-=1
  A.append((u,v))
  D[u]+=1;D[v]+=1 
  DD[u].append((v,i))
  DD[v].append((u,i))
V=[-1]*N
#print(D)
from collections import deque
d=deque()
for i in range(N):
  if D[i]==1:
    d.append(i)

while d:
  now=d.popleft()
  for nex,i in DD[now]:
    if V[nex]==1:
      continue
    B.append((now,nex))
    D[now]-=1;D[nex]-=1
    V[now]=1
    if D[nex]==1:
      d.append(nex)
      
#print(B)
F=[[] for i in range(N)]
for u,v in B:
  F[u].append(v)
for i in range(N):
  F[i]=set(F[i])

ans=[0]*N
for i in range(N):
  u,v=A[i]
  if v in F[u]:
    ans[i]=1 
  if u in F[v]:
    ans[i]=-1 
d=deque();f=0;V=[1]*N
for i in range(N):
  if D[i]==2 and f==0:
    g=i;f=1
  if D[i]==2:
    V[i]=-1 


for nex,i in DD[g]:
  if V[nex]==-1:
    s=nex
    break
#print(V,s,g,DD)
FF=[[] for i in range(N)]
FF[g].append(s)
#print('FF',FF)
d.append(s)
#print(d,s,g)
while d:
  now=d.popleft()
  #print(now,DD[now])
  for nex,i in DD[now]:
    if now==s and nex==g:
      continue 
    if V[nex]==-1:
      V[now]=1
      FF[now].append(nex)
      d.append(nex)

for i in range(N):
  FF[i]=set(FF[i])
for i in range(N):
  if ans[i]==0:
    u,v=A[i]
    if u in FF[v]:
      ans[i]=1
    else:
      ans[i]=-1 
for i in ans:
  if i==-1:
    print('<-')
  else:
    print('->')
0