def merge (a, b):
if a == (): return build_tree (b)
if b == (): return a
if b[0] == a[0]:
if len (a) > 1 and isinstance (a[1], type (())):
return (a[0],) + (merge (a[1], b[1:]),) + a[2:]
elif b[1:] == (): return a
else: return (a[0],) + (build_tree (b[1:]),) + a[1:]
else:
return (a[0],) + merge (a[1:], b)