测试输入包含若干测试用例。每个测试用例的第1行给出两个正整数,分别是节点数N ( 1 < N < 1000 )和边数M;随后的M行对应M条边,每行给出一对正整数,分别是该条边直接连通的两个节点的编号(节点从1到N编号)。当N为0时输入结束。
每个测试用例的输出占一行,若欧拉回路存在则输出1,否则输出0。
3 3 1 2 1 3 2 3 3 2 1 2 2 3 0
1 0
判断各个节点的度是否为偶数,自环增加度为2,不影响,所以可以加上去
while True:
try:
n,m = list(map(int, input().split()))
if n == 0:
break
nodes = [0 for i in range(n+1)]
for i in range(m):
temp = list(map(int, input().split()))
nodes[temp[0]] += 1
nodes[temp[1]] += 1
whetherEuler = True
for i in range(1,n+1):
if nodes[i] % 2 == 1:
whetherEuler = False
break
if whetherEuler:
print(1)
else:
print(0)
except Exception:
break