This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
haas:fall2014:data:projects:dlt0 [2014/11/17 12:58] – [list library] wedge | haas:fall2014:data:projects:dlt0 [2014/11/22 14:51] (current) – [Errata] wedge | ||
---|---|---|---|
Line 11: | Line 11: | ||
This section will document any updates applied to the project since original release: | This section will document any updates applied to the project since original release: | ||
- | * __revision | + | * __revision |
+ | * unit-addnode had a typo where it was expecting an empty tree to have a height of 0 instead of -1 (FIXED) | ||
+ | * unit-traverse had a number of typos, and saw some increased ruggedness: | ||
+ | * missing semi-colon on line 15 (FIXED) | ||
+ | * invalid variable reference (myList instead of tmpList) on/around line 52 (FIXED) | ||
+ | * extra checks to test invalid modes | ||
+ | * unit-set_mode has been deployed | ||
+ | * valid and invalid modes are checked | ||
+ | * unit-searchtree has been deployed | ||
+ | * NULL, empty, and non-empty tree searches of valid and invalid values | ||
+ | * verify-node.sh has been updated to show absolute totals | ||
+ | * verify-tree.sh has been updated to include new unit tests in its totals | ||
+ | * __revision 2__: new unit tests and verify scripts added (20141121) | ||
+ | * unit-balance has been deployed | ||
+ | * corresponding verify-balance.sh has been deployed | ||
+ | * the unit test for balance assumes a pivot based on the middle (if odd), or left-middle (if even) node | ||
+ | * unit-grabnode has been deployed | ||
+ | * corresponding verify-grabnode.sh has been deployed | ||
+ | * the grabnode unit test, like traverse, tests all 3 implementations in one unit test | ||
+ | * verify-tree.sh has been updated to include new unit tests | ||
+ | * __revision 3__: tweaks, comments, and new unit tests and verify script added (20141122) | ||
+ | * unit-grabnode may not have been working truly as intended. FIXED | ||
+ | * also added a specific test for grabbing from a single node tree | ||
+ | * performs 6 tests in total- NULL, empty, one-node, one node grabbed, two nodes grabbed, three nodes grabbed | ||
+ | * unit-addnode has added tests (looks like 35 in total when correctly implemented) | ||
+ | * unit-copytree has been deployed | ||
+ | * corresponding verify-copytree.sh has been deployed | ||
+ | * we perform 6 tests- NULL, empty, one-node, populated, populated and balanced, populated and node grabbed | ||
+ | * verify-tree.sh has been updated to include new unit test | ||
=====Objective===== | =====Objective===== | ||
Line 40: | Line 68: | ||
* a tree has a **root** which forms the basis or starting point of the structure; all nodes are reachable (and related through means of descendance) from the root. | * a tree has a **root** which forms the basis or starting point of the structure; all nodes are reachable (and related through means of descendance) from the root. | ||
* to put an item on the tree, we insert or **add** it (which you will have 3 separate opportunities to implement in this project!). When we add a node to the tree, it gets positioned in the appropriately available child link off some parent node. | * to put an item on the tree, we insert or **add** it (which you will have 3 separate opportunities to implement in this project!). When we add a node to the tree, it gets positioned in the appropriately available child link off some parent node. | ||
- | * to get an item off of the tree, we **get** it. Just as with a list, disconnecting a node from the structure can involve a lot of work to maintain connections and overall integrity of the data structure. | + | * to get an item off of the tree, we **grab** it (my term- often times it is referred to as deleting a node from the tree). Just as with a list, disconnecting a node from the structure can involve a lot of work to maintain connections and overall integrity of the data structure. |
+ | * an important action that will be taking place is the traversal of the tree- ie walking it in certain orders to achieve desired results (sorting/ | ||
As we will be placing nodes in the tree according to their stored values (lesser values go to the left, or previous; greater values go to the right, or next), our tree will naturally sort our data for us. | As we will be placing nodes in the tree according to their stored values (lesser values go to the left, or previous; greater values go to the right, or next), our tree will naturally sort our data for us. | ||
Line 83: | Line 112: | ||
#define _TREE_H | #define _TREE_H | ||
- | #include "node.h" | + | #include "list.h" |
- | # | + | # |
- | # | + | # |
- | # | + | # |
- | # | + | # |
- | # | + | # |
- | # | + | # |
+ | typedef struct tree Tree; | ||
struct tree { | struct tree { | ||
Node *root; | Node *root; | ||
- | char | + | char max_height; |
- | char | + | char height; |
- | Tree *(*add) (Tree *, Node * ); // addnode node (function pointer) | + | Tree *(*copy)(Tree * |
- | | + | |
- | | + | |
}; | }; | ||
- | typedef struct tree Tree; | ||
Tree *mktree | Tree *mktree | ||
Line 107: | Line 136: | ||
Tree *set_mode | Tree *set_mode | ||
- | Tree *addnode_s | + | Tree *addnode |
- | Tree *addnode_r | + | |
- | Tree *addnode_i | + | Tree *copytree_s(Tree * |
+ | Tree *copytree_r(Tree * | ||
+ | Tree *copytree_i(Tree * ); // copy/ | ||
+ | |||
+ | Node *searchtree(Tree *, char ); // find node in tree | ||
- | Node *findnode_s(Tree *, char ); // stack-based | + | Tree *grabnode_s(Tree *, Node **); // stack-based |
- | Node *findnode_r(Tree *, char ); // recursive | + | Tree *grabnode_r(Tree *, Node **); // recursive |
- | Node *findnode_i(Tree *, char ); // iterative | + | Tree *grabnode_i(Tree *, Node **); // iterative |
- | Tree *getnode_s | + | List *traverse_s(Tree *, char ); // stack-based |
- | Tree *getnode_r | + | List *traverse_r(Tree *, char ); // recursive |
- | Tree *getnode_i | + | List *traverse_i(Tree *, char ); // iterative |
- | Tree *cptree | ||
Tree *rmtree | Tree *rmtree | ||
- | Tree *balance | + | Tree *balance |
- | void show_tree (Tree *, char | ||
void print_tree(Tree * | void print_tree(Tree * | ||
Line 140: | Line 171: | ||
As the layers and complexities rise, narrowing down the source of errors becomes increasingly important. | As the layers and complexities rise, narrowing down the source of errors becomes increasingly important. | ||
- | If your tree addnode_i() isn't working, is it because of a problem with your tree? Or might it be in an underlying node operation it relies upon? | + | If your tree copytree_i() isn't working, is it because of a problem with your tree? Or might it be in an underlying node operation it relies upon? |
To aid you in your development efforts, you now have the ability to import functioning node, list, and stack implementations into your project for the purposes of testing your tree functionality. | To aid you in your development efforts, you now have the ability to import functioning node, list, and stack implementations into your project for the purposes of testing your tree functionality. | ||
Line 175: | Line 206: | ||
===Reverting back to using your code=== | ===Reverting back to using your code=== | ||
- | If you were trying out the reference implementation to verify | + | If you were trying out the reference implementation to verify |
<cli> | <cli> | ||
Line 182: | Line 213: | ||
lab46: | lab46: | ||
</ | </ | ||
- | ====List Library unit tests==== | + | ====Node Library unit tests==== |
- | As a result of the required changes to **display()**, an updated unit test will be released (this will mean a different number of total tests for list than previously). | + | As a result of the addition of **other**, an updated |
- | Be sure to run the various | + | Be sure to run the various |
- | ====Queue library unit tests==== | + | ====Tree library unit tests==== |
- | In **testing/queue/unit/**, you will find these files: | + | In **testing/tree/unit/**, you will // |
- | * **unit-mkqueue.c** - unit test for **mkqueue()** library function | + | * **unit-addnode.c** - unit test for the various |
- | * **unit-cpqueue.c** - unit test for **cpqueue()** library function | + | * **unit-searchtree.c** - unit test for the various |
- | * **unit-rmqueue.c** - unit test for **rmqueue()** library | + | * **unit-grab.c** - unit test for **grabnode_*()** library |
- | * **unit-enqueue.c** - unit test for **enqueue()** library function | + | * **unit-set_mode.c** - unit test for **set_mode()** library function |
- | * **unit-dequeue.c** - unit test for **dequeue()** library function | + | * **unit-balance.c** - unit test for **balance()** library function |
- | * **unit-purge.c** - unit test for **purge()** library | + | * **unit-treeops.c** - unit test for {mk,rm}tree library functions |
+ | | ||
+ | * **unit-print.c** - unit test for displaying tree structure | ||
- | There are also corresponding | + | **NOTE**: At the time of project release, unit tests are not yet available; so they will be released as they are developed. |
- | These are complete runnable programs (when compiled, and linked against the queue library, which is all handled for you by the **Makefile** system in place). | + | There are also corresponding **verify-FUNCTION.sh** scripts that will output a " |
+ | |||
+ | These are complete runnable programs (when compiled, and linked against the tree library, which is all handled for you by the **Makefile** system in place). | ||
Of particular importance, I want you to take a close look at: | Of particular importance, I want you to take a close look at: | ||
Line 214: | Line 249: | ||
=====Expected Results===== | =====Expected Results===== | ||
- | To assist you in verifying a correct implementation, | + | To assist you in verifying a correct implementation, |
Line 221: | Line 256: | ||
<cli> | <cli> | ||
- | lab46: | + | lab46: |
==================================================== | ==================================================== | ||
- | = Verifying Doubly-Linked | + | = Verifying Doubly-Linked |
==================================================== | ==================================================== | ||
- | [mklist] Total: | + | [mknode] Total: |
- | [cplist] Total: | + | [cpnode] Total: |
- | [rmlist] Total: | + | [rmnode] Total: |
- | [append] Total: | + | |
- | [insert] Total: | + | |
- | [obtain] Total: | + | |
- | | + | |
- | [findnode] Total: | + | |
- | [sortlist] Total: | + | |
- | [swapnode] Total: | + | |
==================================================== | ==================================================== | ||
- | | + | |
==================================================== | ==================================================== | ||
lab46: | lab46: | ||
Line 244: | Line 272: | ||
- | ====queue library==== | + | ====tree library==== |
- | Here is what you should get for queue: | + | Here is what you should get for tree: |
<cli> | <cli> | ||
- | lab46: | + | lab46: |
- | =================================================== | + | coming soon |
- | = | + | lab46: |
- | =================================================== | + | |
- | [mkqueue] Total: | + | |
- | [cpqueue] Total: | + | |
- | [rmqueue] Total: | + | |
- | [purge] Total: | + | |
- | [enqueue] Total: | + | |
- | [dequeue] Total: | + | |
- | =================================================== | + | |
- | [RESULTS] Total: | + | |
- | =================================================== | + | |
- | lab46: | + | |
</ | </ | ||
Line 268: | Line 285: | ||
* Project must be submit on time, by the posted deadline. | * Project must be submit on time, by the posted deadline. | ||
- | * Late submissions will lose 25% credit per day, with the submission window closing on the 4th day following the deadline. | + | * As this project is due at the very end of the semester, there is no late window. It is either submitted, or it is not. |
* All code must compile cleanly (no warnings or errors) | * All code must compile cleanly (no warnings or errors) | ||
* all requested functions must be implemented in the related library | * all requested functions must be implemented in the related library |