- fork this repository
- write all of your code in a directory named
lab-
+<your name>
e.g.lab-duncan
- push to your repository
- submit a pull request to this repository
- submit a link to your PR in canvas
- write a question and observation on canvas
Your lab directory must include
- README.md -- with a documentation about your lab
- .gitignore -- with a robust .gitignore
- .eslintrc.json -- with the class .eslintrc.json file
- .eslintignore -- with the class .eslintignore
- .package.json -- with all dependencies and dev-dependencies
- lib/ -- directory for holding your programs helper modules
- test/ -- directory for holding your programs unit and integration tests
- in your README, write documentation for your data structures
- your documentation should includes code block usage examples
- provide instructions for:
- installing and using your data structure
- accessing each method
- running your tests
- Add a
remove(value)
method to the BinarySearchTree class presented in class.
-
Add a
remove(value)
method to the BinarySearchTree class presented in class. -
Implement a K-ary-Tree Constructor (not an ES6 class)
- implement the following prototype methods
find(value)
should iterate over all child nodes using a breath-first traversal and return the first node that has that value, it should return null if a node with the value is not foundtoString(str)
should iterate over all child nodes using a breath-first traversal and concatenate their values separated by newlines in to a stringtoArray(array)
should use a depth-first traversal and push all the tree's elements into an array.
- implement the following prototype methods
In the readme.md
of your application, include the Big O complexity (time and space) for all the implemented methods.
- Write at least 2 unit tests (one normal cases and one edge case) for every implemented method.
- Organize your tests into appropriate describe blocks for test output readability