logo

La seqüència consecutiva més llarga de l'arbre binari

Prova-ho a GfG Practice La seqüència consecutiva més llarga de l'arbre binari' title= #practiceLinkDiv { mostrar: cap !important; }

Donat un arbre binari, trobeu la longitud del camí més llarg que consta de nodes amb valors consecutius en ordre creixent. Cada node es considera com un camí de longitud 1.
Exemples:  
 

In below diagram binary tree with longest consecutive path(LCP) are shown :

Pràctica recomanada La seqüència consecutiva més llarga de l'arbre binari Prova-ho!

Podem resoldre el problema anterior de forma recursiva. A cada node necessitem informació del seu node pare si el node actual té un valor més que el seu node pare, llavors fa un camí consecutiu a cada node, compararem el valor del node amb el seu valor pare i actualitzarem el camí consecutiu més llarg en conseqüència. 



Per obtenir el valor del node pare passarem el (node_value + 1) com a argument al mètode recursiu i compararem el valor del node amb aquest valor de l'argument si satisfà actualitzem la longitud actual del camí consecutiu, en cas contrari, reiniciarem la longitud del camí actual en 1. 

Si us plau, consulteu el codi següent per entendre millor: 

C++
// C/C++ program to find longest consecutive // sequence in binary tree #include    using namespace std; /* A binary tree node has data pointer to left  child and a pointer to right child */ struct Node {  int data;  Node *left *right; }; // A utility function to create a node Node* newNode(int data) {  Node* temp = new Node;  temp->data = data;  temp->left = temp->right = NULL;  return temp; } // Utility method to return length of longest // consecutive sequence of tree void longestConsecutiveUtil(Node* root int curLength  int expected int& res) {  if (root == NULL)  return;  // if root data has one more than its parent  // then increase current length  if (root->data == expected)  curLength++;  else  curLength = 1;  // update the maximum by current length  res = max(res curLength);  // recursively call left and right subtree with  // expected value 1 more than root data  longestConsecutiveUtil(root->left curLength  root->data + 1 res);  longestConsecutiveUtil(root->right curLength  root->data + 1 res); } // method returns length of longest consecutive // sequence rooted at node root int longestConsecutive(Node* root) {  if (root == NULL)  return 0;  int res = 0;  // call utility method with current length 0  longestConsecutiveUtil(root 0 root->data res);  return res; } // Driver code to test above methods int main() {  Node* root = newNode(6);  root->right = newNode(9);  root->right->left = newNode(7);  root->right->right = newNode(10);  root->right->right->right = newNode(11);  printf('%dn' longestConsecutive(root));  return 0; } 
Java
// Java program to find longest consecutive  // sequence in binary tree class Node {  int data;  Node left right;  Node(int item)  {  data = item;  left = right = null;  } } class Result  {  int res = 0; } class BinaryTree {  Node root;  // method returns length of longest consecutive   // sequence rooted at node root   int longestConsecutive(Node root)  {  if (root == null)  return 0;  Result res = new Result();    // call utility method with current length 0   longestConsecutiveUtil(root 0 root.data res);    return res.res;  }  // Utility method to return length of longest   // consecutive sequence of tree   private void longestConsecutiveUtil(Node root int curlength   int expected Result res)  {  if (root == null)  return;  // if root data has one more than its parent   // then increase current length   if (root.data == expected)  curlength++;  else  curlength = 1;  // update the maximum by current length   res.res = Math.max(res.res curlength);  // recursively call left and right subtree with   // expected value 1 more than root data   longestConsecutiveUtil(root.left curlength root.data + 1 res);  longestConsecutiveUtil(root.right curlength root.data + 1 res);  }  // Driver code  public static void main(String args[])   {  BinaryTree tree = new BinaryTree();  tree.root = new Node(6);  tree.root.right = new Node(9);  tree.root.right.left = new Node(7);  tree.root.right.right = new Node(10);  tree.root.right.right.right = new Node(11);  System.out.println(tree.longestConsecutive(tree.root));  } } // This code is contributed by shubham96301 
Python3
# Python3 program to find longest consecutive  # sequence in binary tree  # A utility class to create a node  class newNode: def __init__(self data): self.data = data self.left = self.right = None # Utility method to return length of  # longest consecutive sequence of tree  def longestConsecutiveUtil(root curLength expected res): if (root == None): return # if root data has one more than its  # parent then increase current length  if (root.data == expected): curLength += 1 else: curLength = 1 # update the maximum by current length  res[0] = max(res[0] curLength) # recursively call left and right subtree  # with expected value 1 more than root data  longestConsecutiveUtil(root.left curLength root.data + 1 res) longestConsecutiveUtil(root.right curLength root.data + 1 res) # method returns length of longest consecutive  # sequence rooted at node root  def longestConsecutive(root): if (root == None): return 0 res = [0] # call utility method with current length 0  longestConsecutiveUtil(root 0 root.data res) return res[0] # Driver Code if __name__ == '__main__': root = newNode(6) root.right = newNode(9) root.right.left = newNode(7) root.right.right = newNode(10) root.right.right.right = newNode(11) print(longestConsecutive(root)) # This code is contributed by PranchalK 
C#
// C# program to find longest consecutive  // sequence in binary tree  using System;  class Node  {   public int data;   public Node left right;   public Node(int item)   {   data = item;   left = right = null;   }  }  class Result  {   public int res = 0;  }  class GFG  {   Node root;   // method returns length of longest consecutive   // sequence rooted at node root   int longestConsecutive(Node root)   {   if (root == null)   return 0;   Result res = new Result();     // call utility method with current length 0   longestConsecutiveUtil(root 0 root.data res);     return res.res;   }   // Utility method to return length of longest   // consecutive sequence of tree   private void longestConsecutiveUtil(Node root int curlength   int expected Result res)   {   if (root == null)   return;   // if root data has one more than its parent   // then increase current length   if (root.data == expected)   curlength++;   else  curlength = 1;   // update the maximum by current length   res.res = Math.Max(res.res curlength);   // recursively call left and right subtree with   // expected value 1 more than root data   longestConsecutiveUtil(root.left curlength   root.data + 1 res);   longestConsecutiveUtil(root.right curlength   root.data + 1 res);   }   // Driver code   public static void Main(String []args)   {   GFG tree = new GFG();   tree.root = new Node(6);   tree.root.right = new Node(9);   tree.root.right.left = new Node(7);   tree.root.right.right = new Node(10);   tree.root.right.right.right = new Node(11);   Console.WriteLine(tree.longestConsecutive(tree.root));   }  }  // This code is contributed by 29AjayKumar 
JavaScript
<script> // JavaScript program to find longest consecutive  // sequence in binary tree class Node {  constructor(item)  {  this.data=item;  this.left = this.right = null;  } } let res = 0; let root; function longestConsecutive(root) {  if (root == null)  return 0;    res=[0];     // call utility method with current length 0   longestConsecutiveUtil(root 0 root.data res);    return res[0]; }  // Utility method to return length of longest   // consecutive sequence of tree  function longestConsecutiveUtil(rootcurlength expectedres) {  if (root == null)  return;    // if root data has one more than its parent   // then increase current length   if (root.data == expected)  curlength++;  else  curlength = 1;    // update the maximum by current length   res[0] = Math.max(res[0] curlength);    // recursively call left and right subtree with   // expected value 1 more than root data   longestConsecutiveUtil(root.left curlength   root.data + 1 res);  longestConsecutiveUtil(root.right curlength   root.data + 1 res); } // Driver code root = new Node(6); root.right = new Node(9); root.right.left = new Node(7); root.right.right = new Node(10); root.right.right.right = new Node(11); document.write(longestConsecutive(root)); // This code is contributed by rag2127 </script> 

Sortida
3

Complexitat temporal: O(N) on N és el nombre de nodes en un arbre binari determinat.
Espai auxiliar: O(log(N))
També es parla a l'enllaç següent: 
Longitud màxima del camí creixent consecutiu en arbre binari