Assignment Three

 

            This assignment has two parts. The first part is to add code to the binary tree class BinaryTree.java  to draw the binary tree. The getDrawSize() method and the draw(Graphics g) methods must be implemented and  the InorderIterator class must be modified. The BinaryTreeNode class (an inner class of BinaryTree) has fields for the x and y coordinates of each node. The draw parameters and the coordinates are assigned as follows:

·        The diameter field is the diameter of the ovals that are drawn for each node.

·        The font size for drawing the name (number) of each node should be diameter also.

·        The x coordinate is the inorder sequence number of the node multiplied by a factor (for example 2*diameter works OK).

·        The y coordinate is the depth of the node multiplied by a factor (for example 4*diameter works OK).

 

Draw the filled ovals at the (x, y) coordinates of each node. Lines from a node to each of its children must be drawn also. A way to do this is to do an inorder iteration of the tree to calculate the x and/or y values of each node and then do another iteration (possibly a preorder iteration) and draw the ovals and lines to the children. Lines must also be draw to null children. You can use BinaryTreeExample.java to test this part of the assignment.

          For the second part of the assignment, you are to create an ExpressionTree class. The Expression Tree class extends the BinaryTree class.  See ExpressionTree.java for a guide. The class has a static method to construct an expression tree (see page 380-395 in the text) from an algebraic expression. The operators are the binary operators +, -, *, / and ^ (exponentiation) and the parenthesis operators, ( and ). The operands are non-negative integers and variables made up of single letters only. Methods to return the fully parenthesized infix notation of the expression, the prefix notation of the expression , the postfix notation of the expression and sample intermediate code of the expression as Strings are to be included in the ExpresstionTree class. The intermediate code statements are:

Push operand { Push the operand on the Stack }

 Add { Pop the Stack into left, pop the Stack into right and push left + right }

 Sub { Pop the Stack into left, pop the Stack into right and push left - right }

 Mul { Pop the Stack into left, pop the Stack into right and push left * right }

 Div { Pop the Stack into left, pop the Stack into right and push left / right }

 Pow { Pop the Stack into left, pop the Stack into right and push left ^ right }

 Pop result { Pop the Stack into result }

 Operands can be a single letter variable or an integer.

The algebraic expression to expression tree algorithm will be discussed in class. If there are errors in the expression then throw an exception.

Use TestExpressionTree.java to test your implementations.

Your output should be similar to: