863.All-Nodes-Distance-K-in-Binary-Tree
863. All Nodes Distance K in Binary Tree
题目地址
https://leetcode.com/problems/all-nodes-distance-k-in-binary-tree/
题目描述
We are given a binary tree (with root node root), a target node, and an integer value K.
Return a list of the values of all nodes that have a distance K from the target node. The answer can be returned in any order.
Example 1:
Input: root = [3,5,1,6,2,0,8,null,null,7,4], target = 5, K = 2
Output: [7,4,1]
Explanation:
The nodes that are a distance 2 from the target node (with value 5)
have values 7, 4, and 1.
Note that the inputs "root" and "target" are actually TreeNodes.
The descriptions of the inputs above are just serializations of these objects.
Note:
The given tree is non-empty.
Each node in the tree has unique values 0 <= node.val <= 500.
The target node is a node in the tree.
0 <= K <= 1000.代码
Approach #1 Parent Map
Approach #2 Percolate Distance
Algorithm
Traverse every node with a depth first search dfs. We'll add all nodes x to the answer such that node is the node on the path from x to target that is closest to the root.
To help us, dfs(node) will return the distance from node to the target. Then, there are 4 cases:
If
node == target, then we should add nodes that are distanceKin the subtree rooted attarget.If
targetis in the left branch ofnode, say at distanceL+1, then we should look for nodes that are distanceK - L - 1in the right branch.If
targetis in the right branch ofnode, the algorithm proceeds similarly.If
targetisn't in either branch ofnode, then we stop.
Complexity Analysis
Time Complexity: O_(_N), where N is the number of nodes in the given tree.
Space Complexity: O_(_N).
Last updated
Was this helpful?