Closed3

パスグラフの判定条件 - ABC287 - C

KanonKanon
  1. graphが連結であること
  2. 全てのnodeは、nodeから出てる辺が2本以下である
  3. 両端のnodeのみ出てる辺が1本である

この3つの条件を満たす場合が答え

KanonKanon
import sys
sys.setrecursionlimit(10**6)

def dfs(visited, g, v):
    visited[v] = True
    for to in g[v]:
        if visited[to]:
          continue
        #! 再帰的に探索
        dfs(visited, g, to)
    return visited

n,m = map(int, input().split())
graph = [[] for _ in range(0,n)]
visited = [False for _ in range(0,n)]

for i in range(m):
  a,b = map(int, input().split())
  a-=1
  b-=1
  graph[a].append(b)
  graph[b].append(a)

dfs(visited, graph, 0)
if not all(visited):
  print('No')
  exit()

edge = 0
for node in graph:
  if len(node) == 1:
    edge += 1
  elif len(node) != 2:
    print('No')
    exit()

if edge == 2:
  print('Yes')
else:
  print('No')
このスクラップは2ヶ月前にクローズされました