二叉树公共祖先问题
二叉树的最近公共先祖, 在二叉树中分配硬币
# 二叉树先祖问题
# 1.1.二叉树的最近公共祖先 (opens new window)
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。
百度百科 (opens new window)中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”
示例 1:
输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 1 输出:3 解释:节点 5 和节点 1 的最近公共祖先是节点 3 。
1
2
3示例 2:
输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 4 输出:5 解释:节点 5 和节点 4 的最近公共祖先是节点 5 。因为根据定义最近公共祖先节点可以为节点本身。
1
2
3示例 3:
输入:root = [1,2], p = 1, q = 2 输出:1
1
2
1
1
// Make sure to add code blocks to your code group
# 1.2. 在二叉树中分配硬币 (opens new window)
给你一个有
n
个结点的二叉树的根结点root
,其中树中每个结点node
都对应有node.val
枚硬币。整棵树上一共有n
枚硬币。在一次移动中,我们可以选择两个相邻的结点,然后将一枚硬币从其中一个结点移动到另一个结点。移动可以是从父结点到子结点,或者从子结点移动到父结点。
返回使每个结点上 只有 一枚硬币所需的 最少 移动次数。
示例 1:
输入:root = [3,0,0] 输出:2 解释:一枚硬币从根结点移动到左子结点,一枚硬币从根结点移动到右子结点。
1
2
3示例 2:
输入:root = [0,3,0] 输出:3 解释:将两枚硬币从根结点的左子结点移动到根结点(两次移动)。然后,将一枚硬币从根结点移动到右子结点。
1
2
3
1
1
// Make sure to add code blocks to your code group
编辑 (opens new window)
上次更新: 2024/12/13 19:48:29