测试输入包含若干测试用例。每个测试用例的第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