Diameter of a Binary Tree
The diameter of a tree (sometimes called the width) is the number of nodes on the longest path between two leaves in the tree. The diagram below shows two trees each with diameter nine, the leaves that form the ends of a longest path are shaded (note that there is more than one path in each tree of length nine, but no path longer than nine nodes).
The diameter of a tree T is the largest of the following quantities:
* the diameter of T’s left subtree
* the diameter of T’s right subtree
* the longest path between leaves that goes through the root of T (this can be computed from the heights of the subtrees of T)
* the diameter of T’s right subtree
* the longest path between leaves that goes through the root of T (this can be computed from the heights of the subtrees of T)
Implementation:
| // Recursive optimized Java program to find the diameter of a// Binary Tree/* Class containing left and right child of current node and key value*/classNode{    intdata;    Node left, right;    publicNode(intitem)    {        data = item;        left = right = null;    }}/* Class to print the Diameter */classBinaryTree{    Node root;    /* Method to calculate the diameter and return it to main */    intdiameter(Node root)    {        /* base case if tree is empty */        if(root == null)            return0;        /* get the height of left and right sub trees */        intlheight = height(root.left);        intrheight = height(root.right);        /* get the diameter of left and right subtrees */        intldiameter = diameter(root.left);        intrdiameter = diameter(root.right);        /* Return max of following three          1) Diameter of left subtree         2) Diameter of right subtree         3) Height of left subtree + height of right subtree + 1 */        returnMath.max(lheight + rheight + 1,                        Math.max(ldiameter, rdiameter));    }    /* A wrapper over diameter(Node root) */    intdiameter()    {        returndiameter(root);    }    /*The function Compute the "height" of a tree. Height is the      number f nodes along the longest path from the root node      down to the farthest leaf node.*/    staticintheight(Node node)    {        /* base case tree is empty */        if(node == null)            return0;        /* If tree is not empty then height = 1 + max of left           height and right heights */        return(1+ Math.max(height(node.left), height(node.right)));    }    publicstaticvoidmain(String args[])    {        /* creating a binary tree and entering the nodes */        BinaryTree tree = newBinaryTree();        tree.root = newNode(1);        tree.root.left = newNode(2);        tree.root.right = newNode(3);        tree.root.left.left = newNode(4);        tree.root.left.right = newNode(5);        System.out.println("The diameter of given binary tree is : "                           + tree.diameter());    }} | 
 
No comments:
Post a Comment