CSCI 2110 - Data Structures and Algorithms - lab 8


  • 作业标题:CSCI 2110 - Data Structures and Algorithms - lab 8
  • 课程名称:Dalhouse University CSCI 2110 Data Structures and Algorithms
  • 完成周期:2天

描述

The objective of this lab is to help you get familiar with binary search trees. Download the example
code/files provided along with this lab document. You will need the following files to complete your
work:

  • BinaryTree.java (Generic BinaryTree Class)
  • BinarySearchTree.java (Generic BinarySearchTree Class)

Note: The Binary Search Tree class will be completed in the lecture on Wednesday, November 17th.

Marking Scheme

This lab has one exercise and requires the completion of three methods, plus a driver program.
Each method/driver program carries 10 points.

Working code, Outputs included, Efficient, Good basic comments included: 10/10

No comments or poor commenting: subtract one point

Unnecessarily inefficient: subtract one point

No outputs and/or not all test cases covered: subtract up to two points

Code not working: subtract up to six points depending upon how many methods are incorrect. TAs can
and will test cases beyond those shown in sample inputs, and may test methods independently.

Your final score will be scaled down to a value out of 10. For example, if there are three exercises and
you score 9/10, 10/10 and 8/10 on the three exercises, your total is 27/30 or 9/10.

Error checking: Unless otherwise specified, you may assume that a user enters the correct data types
and the correct number of input entries, that is, you need not check for errors on input.

Submission: All submissions are through Brightspace. Deadline for submission: Sunday, November
21st, 11.59 PM

What to submit:

Submit one ZIP file containing all source code (files with .java suffixes) and text documents
containing sample outputs. For each exercise you will minimally have to submit a class containing
your completed methods, a demo class, and sample outputs. If you wish, you may combine your
test outputs into a single file called Outputs.txt via cut-and-paste or a similar method.

Your final submission should include the following files: BinaryTree.java, BinarySearchTree.java,
Exercise1.java, Exercise2.java, Outputs.txt.

You MUST SUBMIT .java files that are readable by your TAs. If you submit files that are unreadable
such as .class, you will lose points. Please additionally comment out package specifiers.
Late Submission Penalty: The lab is due on Sunday at 11.59 PM. Late submissions up to 5 hours
(4.59 AM on Monday) will be accepted without penalty. After that, there will be a 10% late penalty
per day on the mark obtained. For example, if you submit the lab on Monday at 12 noon and your
score is 8/10, it will be reduced to 7.2/10. Submissions past two days (48 hours) after the grace
submission time, that is, submission past 4.59 AM Wednesday will not be accepted.

Exercise 1: Binary Search Tree Methods

You have been given the file BinarySearchTree.java. Complete the following methods (these are
given as TODO methods in the BinarySearchTree.java code):

  1. Complete the findMax method in the BinarySearchTree.java file. This method should return the
    maximum data value stored in the binary search tree (i.e., the largest integer or double, the String
    which is lexicographically last).

  2. Complete the findMin method in the BinarySearchTree.java file. This method should return the
    minimum data value stored in the binary search tree (i.e., the smallest integer or double, the String
    which is lexicographically first).

  3. Complete the recursiveSearch method in the BinarySearchTree.java file. This method returns a
    BinaryTree whose data value matches the search key. Your solution must be recursive.

    • Before you begin coding, do a trace with pen and paper to understand how to recurse through

the tree.
- There are two recrusiveSearch methods in the starter code.
- One to be completed
- One which acts as a helper method by calling the second

Once your search method has been implemented and tested, write a program called Exercise1.java
with a main method that does the following:
- Create a binary search tree which stores integers from user input. You will read in integer
values from the user until 0 is entered.
- Construct the BST. The insert method is useful here.
Once your BST has been constructed, perform the following operations:
Print the max element
Print the min element

Prompt the user to search for an element in the tree:

  • Search for an element that exists and print the result
  • Search for an element in the tree that doesn’t exist and print the result

Example input/output

Enter int or '0': 1
Enter int or '0': 2
Enter int or '0': 3
Enter int or '0': 4
Enter int or '0': 5
Enter int or '0': 6
Enter int or '0': 7
Enter int or '0': 8
Enter int or '0': 9
Enter int or '0': 0
The max data value in the BST is: 9
The min data value in the BST is: 1
What key would you like to search for? 3
Found!

Submit the input/output for at least three runs of the program. Do not use the same values as in the
above example. There should be at least one positive test (where the search key is found), and one
negative test (where the search key is not found).

。。。


文章作者: 量子数字
版权声明: 本博客所有文章除特別声明外,均采用 CC BY-NC-ND 4.0 许可协议。转载请注明来源 量子数字 !
  目录