Difference between revisions of "CISC220 F2023 Lab4"
|  (→INPRINT: void inOrderPrint(node)) |  (→POSTEVAL: int postOrderEvaluate(node)) | ||
| Line 13: | Line 13: | ||
| ===<tt>POSTEVAL</tt>: <tt>int postOrderEvaluate(node)</tt>=== | ===<tt>POSTEVAL</tt>: <tt>int postOrderEvaluate(node)</tt>=== | ||
| − | Treat the tree as an "expression tree" for integer arithmetic.   | + | Treat the tree as an "expression tree" for integer arithmetic.  Using a ''post-order traversal'', evaluate the expression represented by the subtree with <tt>node</tt> as its root and return the integer value. | 
| There are 6 operators (4 binary and 2 unary).  All should be evaluated with integer arguments.  The binary operators are <tt>+</tt>, <tt>-</tt>, <tt>*</tt>, and <tt>/</tt>, and <tt>^</tt> for addition, subtraction, multiplication, and division, respectively.  The 2 unary operators are strings: <tt>fact</tt> and <tt>abs</tt>, for the factorial operation and taking the absolute value, respectively.  For unary operators, the operand should be the left child and the right child should be empty/NULL. | There are 6 operators (4 binary and 2 unary).  All should be evaluated with integer arguments.  The binary operators are <tt>+</tt>, <tt>-</tt>, <tt>*</tt>, and <tt>/</tt>, and <tt>^</tt> for addition, subtraction, multiplication, and division, respectively.  The 2 unary operators are strings: <tt>fact</tt> and <tt>abs</tt>, for the factorial operation and taking the absolute value, respectively.  For unary operators, the operand should be the left child and the right child should be empty/NULL. | ||
Revision as of 10:26, 21 September 2023
Contents
Requirements
(5 points) A vector-based implementation of a binary tree of strings is provided in string_binary_tree.cpp (zipped). Your task is to complete the 4 functions below that depend on recursive traversals of a tree read from a file. The main() function expects a single input filename on the command line (reading is taken care of for you) and an output type: PREPRINT, INPRINT, POSTEVAL, or POSTCOUNTCHARS. Each output type triggers a call to one of the functions you must write, as follows:
PREPRINT: void preOrderPrint(node)
Using a pre-order traversal, print every non-NULL element in the subtree with the node specified as its root. Each string printed, including the last, should be followed by a space. The newline is taken care of for you at the end of the no-argument version of this function that starts off the whole recursion.
INPRINT: void inOrderPrint(node)
Using an in-order traversal, print every non-NULL element in the subtree with the node specified as its root.
POSTEVAL: int postOrderEvaluate(node)
Treat the tree as an "expression tree" for integer arithmetic. Using a post-order traversal, evaluate the expression represented by the subtree with node as its root and return the integer value.
There are 6 operators (4 binary and 2 unary). All should be evaluated with integer arguments. The binary operators are +, -, *, and /, and ^ for addition, subtraction, multiplication, and division, respectively. The 2 unary operators are strings: fact and abs, for the factorial operation and taking the absolute value, respectively. For unary operators, the operand should be the left child and the right child should be empty/NULL.
If there is an error or exception of any kind, print "ERROR\n" and exit with code 1.
POSTCOUNTCHARS: int postOrderCountChars(node)
Submission
- Once again, you will submit two files completely through Gradescope: (1) README and (2) your modified string_binary_tree.cpp. As before, the README should contain your name, any AI tool citations/explanations, notes on any limitations or issues with your code, and your interpretation of any ambiguities in the assignment instructions. The code file should also have your name and AI citations per the syllabus.
- Resubmit as many times as you like until the deadline, but be aware that the submission window is kept open for some students to use late days, so a resubmission 2 days after the deadline is not free.
- The 5 possible points assigned by the autograder are provisional. They are not final until published and they may be revised if we determine that your code and/or README do not satisfy the assignment requirements even though they pass the tests. In rare cases, we may also revise your grade upward if we believe that the score you received does not reflect the work you put into the assignment.
