c++ - Path of the diameter of a binary tree -


i have binary tree , method size of longest path (the diameter):

int diameter(struct node * tree) {     if (tree == 0)      return 0;    int lheight = height(tree->left);   int rheight = height(tree->right);    int ldiameter = diameter(tree->left);   int rdiameter = diameter(tree->right);    return max(lheight + rheight + 1, max(ldiameter, rdiameter)); }  

i want function return exact path (list of nodes of diameter). how can it?

thanks

you have 2 options: a) think. b) search. among first few google hits can find this: http://login2win.blogspot.hu/2012/07/print-longest-path-in-binary-tree.html

choose a) if want learn, choose b) if not care, want quick, albeit not perfect solution.

there many possible solutions, of them:

  1. in divide , conquer approach end maintaining far longest paths on both sides, , keep longer.
  2. the quoted solution 2 traversals, 1 determining diameter, , second printing. nice trick overcome problem of not knowing whether @ deepest point in approach 1.
  3. instead of depth first search, breadth first one. use queue. proceed level level, each node storing parent. when reach last level (no children added queue), can print whole path easily, because last printed node on (one) longest path, , have parent links.

Comments

Popular posts from this blog

c++ - Function signature as a function template parameter -

algorithm - What are some ways to combine a number of (potentially incompatible) sorted sub-sets of a total set into a (partial) ordering of the total set? -

How to call a javascript function after the page loads with a chrome extension? -