結果
問題 | No.1424 Ultrapalindrome |
ユーザー | ygd. |
提出日時 | 2021-03-12 21:50:13 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 449 ms / 2,000 ms |
コード長 | 911 bytes |
コンパイル時間 | 194 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 193,792 KB |
最終ジャッジ日時 | 2024-04-22 17:02:53 |
合計ジャッジ時間 | 5,342 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 39 ms
51,968 KB |
testcase_01 | AC | 39 ms
52,352 KB |
testcase_02 | AC | 38 ms
52,224 KB |
testcase_03 | AC | 38 ms
52,224 KB |
testcase_04 | AC | 40 ms
51,840 KB |
testcase_05 | AC | 42 ms
52,096 KB |
testcase_06 | AC | 42 ms
51,968 KB |
testcase_07 | AC | 43 ms
51,968 KB |
testcase_08 | AC | 47 ms
51,968 KB |
testcase_09 | AC | 166 ms
84,864 KB |
testcase_10 | AC | 205 ms
85,760 KB |
testcase_11 | AC | 162 ms
83,072 KB |
testcase_12 | AC | 151 ms
84,480 KB |
testcase_13 | AC | 97 ms
77,568 KB |
testcase_14 | AC | 178 ms
84,096 KB |
testcase_15 | AC | 41 ms
52,992 KB |
testcase_16 | AC | 118 ms
81,152 KB |
testcase_17 | AC | 127 ms
81,664 KB |
testcase_18 | AC | 145 ms
81,152 KB |
testcase_19 | AC | 175 ms
83,072 KB |
testcase_20 | AC | 122 ms
78,336 KB |
testcase_21 | AC | 218 ms
87,040 KB |
testcase_22 | AC | 142 ms
80,128 KB |
testcase_23 | AC | 86 ms
77,056 KB |
testcase_24 | AC | 117 ms
78,976 KB |
testcase_25 | AC | 108 ms
77,952 KB |
testcase_26 | AC | 185 ms
84,352 KB |
testcase_27 | AC | 220 ms
89,216 KB |
testcase_28 | AC | 247 ms
162,816 KB |
testcase_29 | AC | 449 ms
193,792 KB |
testcase_30 | AC | 155 ms
91,136 KB |
testcase_31 | AC | 139 ms
88,704 KB |
ソースコード
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")