Given a binary tree, find the length of the longest consecutive sequence path.
The path refers to any sequence of nodes from some starting node to any node in the tree along the parent-child connections. The longest consecutive path need to be from parent to child (cannot be the reverse).
Example
For example,
1
\
3
/ \
2 4
\
5
Longest consecutive sequence path is3-4-5, so return3.
2
\
3
/
2
/
1
Longest consecutive sequence path is2-3,not3-2-1, so return2.
public int longest=0;
public int longestConsecutive(TreeNode root){
helper(root);
return longest;
}
public int helper(TreeNode root){
if(root==null){
return 0;
}
int result=1;
int left=helper(root.left);
int right=helper(root.right);
if(root.left!=null && root.val+1==root.left.val){
result=Math.max(result,left+1);
}
if(root.right!=null && root.val+1==root.right.val){
result=Math.max(result,right+1);
}
if(result>longest){
longest=result;
}
return result;
}
// version 1: Traverse + Divide Conquer
public class Solution {
/**
* @param root the root of binary tree
* @return the length of the longest consecutive sequence path
*/
public int longestConsecutive(TreeNode root) {
return helper(root, null, 0);
}
private int helper(TreeNode root, TreeNode parent, int lengthWithoutRoot) {
if (root == null) {
return 0;
}
int length = (parent != null && parent.val + 1 == root.val)
? lengthWithoutRoot + 1
: 1;
int left = helper(root.left, root, length);
int right = helper(root.right, root, length);
return Math.max(length, Math.max(left, right));
}
}
// version 2: Another Traverse + Divide Conquer
public class Solution {
private int longest;
/**
* @param root the root of binary tree
* @return the length of the longest consecutive sequence path
*/
public int longestConsecutive(TreeNode root) {
longest = 0;
helper(root);
return longest;
}
private int helper(TreeNode root) {
if (root == null) {
return 0;
}
int left = helper(root.left);
int right = helper(root.right);
int subtreeLongest = 1; // at least we have root
if (root.left != null && root.val + 1 == root.left.val) {
subtreeLongest = Math.max(subtreeLongest, left + 1);
}
if (root.right != null && root.val + 1 == root.right.val) {
subtreeLongest = Math.max(subtreeLongest, right + 1);
}
if (subtreeLongest > longest) {
longest = subtreeLongest;
}
return subtreeLongest;
}
}
// version 3: Divide Conquer
public class Solution {
private class ResultType {
int maxInSubtree;
int maxFromRoot;
public ResultType(int maxInSubtree, int maxFromRoot) {
this.maxInSubtree = maxInSubtree;
this.maxFromRoot = maxFromRoot;
}
}
/**
* @param root the root of binary tree
* @return the length of the longest consecutive sequence path
*/
public int longestConsecutive(TreeNode root) {
return helper(root).maxInSubtree;
}
private ResultType helper(TreeNode root) {
if (root == null) {
return new ResultType(0, 0);
}
ResultType left = helper(root.left);
ResultType right = helper(root.right);
// 1 is the root itself.
ResultType result = new ResultType(0, 1);
if (root.left != null && root.val + 1 == root.left.val) {
result.maxFromRoot = Math.max(
result.maxFromRoot,
left.maxFromRoot + 1
);
}
if (root.right != null && root.val + 1 == root.right.val) {
result.maxFromRoot = Math.max(
result.maxFromRoot,
right.maxFromRoot + 1
);
}
result.maxInSubtree = Math.max(
result.maxFromRoot,
Math.max(left.maxInSubtree, right.maxInSubtree)
);
return result;
}
}