贴一个第一题的解法吧:思路:求最近祖先,然后层次遍历,求路径长。下面是求路径,节点的话,再+1就行 class Node: def __init__(self,val): self.val = val self.left = None self.right = None def countPath(node, a:int, b:int): res = 0 stack = [node] while len(stack) > 0: tmp = [] while len(stack) > 0: t = stack.pop() if t == None: continue if t.val == a or t.val == b: return res tmp.append(t.left) tmp.append(t.right) stack = tmp res += 1 return -float("inf") def nodeDistances(root:None,a:int,b:int): if root == None: return None if root.val == a or root.val == b: return root x = nodeDistances(root.left, a, b) y = nodeDistances(root.right, a, b) if x == None: return y elif y == None: return x else: return root if __name__ == "__main__": root = nodeDistances(node, a, b) if root.val == a or root.val == b: print(max(countPath(root.left,a,b), countPath(root.right,a,b)) + 1) else: print(countPath(root.left,a,b) + countPath(root.right,a,b) + 2)
点赞 评论

相关推荐

2025-11-21 13:44
重庆科技大学 Java
程序员花海:实习太简单了 学历可以的 实习描述应该是先介绍业务 再介绍技术 技术咋推动业务的 做到了啥收益 有没有做实验 实验组和对照组有什么不同 你最后学到了什么 有没有参与处理过线上问题 有没有参与过公司的code review 有没有参与过技术分享 这些都是可以在实习描述中写的 并且实习和项目不一样不会撞车 应该放在最前面 放在教育背景下面 另外项目有点烂大街 可以看下我主页的简历优化案例
秋招,不懂就问
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务