結果
問題 | No.1424 Ultrapalindrome |
ユーザー | ygd. |
提出日時 | 2021-03-12 21:50:13 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 410 ms / 2,000 ms |
コード長 | 911 bytes |
コンパイル時間 | 227 ms |
コンパイル使用メモリ | 82,216 KB |
実行使用メモリ | 194,864 KB |
最終ジャッジ日時 | 2024-10-14 16:11:33 |
合計ジャッジ時間 | 4,805 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 29 |
ソースコード
import sys sys.setrecursionlimit(500000) N = int(input()) G = [[] for _ in range(N)] for _ in range(N-1): a,b = map(int,input().split()) a-=1;b-=1 #0-index G[a].append(b); G[b].append(a) L = [] def dfs1(v,par=-1): #jは次数 L.append(v) for u in G[v]: if u == par: continue dfs1(u,v) break for i in range(N): if len(G[i]) == 1: dfs1(i) break #print(L) if len(L) == N: print("Yes"); exit() #一直線 dic = {} def dfs2(v,par,j): if j in dic: dic[j] += 1 else: dic[j] = 1 for u in G[v]: if u == par: continue dfs2(u,v,j+1) if len(L)%2 != 0: NL = len(L) root = L[NL//2] dfs2(root,-1,0) idx = 1 while idx in dic: if dic[idx] == dic[1]: idx += 1 continue else: print("No");exit() print("Yes") else: print("No")