AVL Operations For part two of this assignment, you will be coding the add() and remove() methods of an AVL. Since trees are naturally recursive structures, each of these methods should be Implemented recursively. IMPORTANT: • You will be given unlimited attempts on this assignment, with no cooldown between submissions. • Please run your code before each submission to ensure that there are no formatting errors! If there are formatting errors in your code, your code will not be graded and a submission attempt will be logged. For more information, please review the Vocareum overview below. AVLNode An AVLNode class is provided to you and will be used to represent the nodes of the tree. This file should be treated as read- only and should not be modified in any way. This AVLNode class contains getter and setter methods to access and mutate the structure of the nodes. Please make sure that you understand how this class works, as interaction with this class is crucial for this assignment. Pointer Reinforcement Since both the add() and remove() methods may change the structure of the tree, we highly recommend that you use a technique called pointer reinforcement. Although using pointer reinforcement is not required, it will help to make your code cleaner, and it'll also help greatly in future assignments if you end up taking the next course in our series! Below is a video created by our 1332 TAS, timestamped to a section on pointer reinforcement. Pointer Reinforcement Overview Balancing The tree should rotate appropriately to ensure that it is always balanced. A tree is balanced if every node's balance factor is either -1, 0, or 1. Keep in mind that you will have to update the balancing information stored in the nodes on the way back up the tree after modifying the tree; the variables are not updated automatically. NOTE: If you have completed part one of this assignment, then you should simply copy and paste your code for updateHeightAndBF, rotateLeft, rotateRight, and balance, into this assignment. Note that you may have to toggle the method visibilities to private. Comparable As stated, the data in the AVL must implement the Comparable interface. As you'll see in the files, the generic typing has been specified to require that it implements the Comparable interface. You use the interface by making a method call like data1.compareTo(data2). This will return an int, and the value tells you how data and data2 are in relation to each other. . If the int is positive, then datal is larger than data2. • If the int is negative, then data is smaller than data2. If the int is zero, then datal equals data2. Note that the returned value can be any integer in Java's int range, not just -1, 0, 1. Successor Recall that earlier in the modules you learned about the successor and predecessor of a node in a tree. As a refresher, the successor of a node, n, is the node in the tree that contains the smallest data that is larger than r's data. The predecessor of a node, n, is the node in the tree that contains the largest data that is smaller than n's data. When removing a node from an AVL that has two children, we can choose to replace the removed node with either it's successor or predecessor. For the 2- child case in remove(), you will be replacing the removed node with its successor node, NOT the predecessor node. For more details, please refer to the javadocs for remove(). Helper Methods You'll also notice that the public method stubs we've provided do not contain the parameters necessary for recursion to work, so these public methods should act as "wrapper methods for you to use. You will have to write private recursive helper methods and call them in these wrapper methods. All of these helper methods must be private. To reiterate, do not change the method headers for the provided methods.

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

provided code: 

AVL Operations
For part two of this assignment, you will be coding the add() and remove() methods of an AVL. Since trees are naturally
recursive structures, each of these methods should be implemented recursively.
IMPORTANT:
• You will be given unlimited attempts on this assignment, with no cooldown between submissions.
• Please run your code before each submission to ensure that there are no formatting errors! If there are
formatting errors in your code, your code will not be graded and a submission attempt will be logged. For
more information, please review the Vocareum overview below.
AVLNode
An AVLNode class is provided to you and will be used to represent the nodes of the tree. This file should be treated as read-
only and should not be modified in any way. This AVLNode class contains getter and setter methods to access and mutate
the structure of the nodes. Please make sure that you understand how this class works, as interaction with this class is
crucial for this assignment.
Pointer Reinforcement
Since both the add() and remove() methods may change the structure of the tree, we highly recommend that you use a
technique called pointer reinforcement. Although using pointer reinforcement is not required, it will help to make your code
cleaner, and it'll also help greatly in future assignments if you end up taking the next course in our series! Below is a video
created by our 1332 TAs, timestamped to a section on pointer reinforcement.
Pointer Reinforcement Overview
Balancing
The tree should rotate appropriately to ensure that it is always balanced. A tree is balanced if every node's
balance factor is either -1, 0, or 1. Keep in mind that you will have to update the balancing information stored in
the nodes on the way back up the tree after modifying the tree; the variables are not updated automatically.
NOTE: If you have completed part one of this assignment, then you should simply copy and paste your code
for updateHeightAndBF, rotateLeft, rotate Right, and balance, into this assignment. Note that you may have to
toggle the method visibilities to private.
Comparable
As stated, the data in the AVL must implement the Comparable interface. As you'll see in the files, the generic typing has
been specified to require that it implements the Comparable interface. You use the interface by making a method call
like data1.compareTo(data2). This will return an int, and the value tells you how data1 and data2 are in relation to each
other.
• If the int is positive, then datal is larger than data2.
• If the int is negative, then datal is smaller than data2.
. If the int is zero, then datal equals data2.
Note that the returned value can be any integer in Java's int range, not just -1, 0, 1.
Successor
Recall that earlier in the modules you learned about the successor and predecessor of a node in a tree. As a refresher, the
successor of a node, n, is the node in the tree that contains the smallest data that is larger than n's data. The predecessor of
a node, n, is the node in the tree that contains the largest data that is smaller than n's data. When removing a node from an
AVL that has two children, we can choose to replace the removed node with either it's successor or predecessor. For the 2-
child case in remove(), you will be replacing the removed node with its successor node, NOT the predecessor node. For
more details, please refer to the javadocs for remove().
Helper Methods
You'll also notice that the public method stubs we've provided do not contain the parameters necessary for recursion to
work, so these public methods should act as "wrapper methods" for you to use. You will have to write private recursive
helper methods and call them in these wrapper methods. All of these helper methods must be private. To reiterate,
do not change the method headers for the provided methods.
Transcribed Image Text:AVL Operations For part two of this assignment, you will be coding the add() and remove() methods of an AVL. Since trees are naturally recursive structures, each of these methods should be implemented recursively. IMPORTANT: • You will be given unlimited attempts on this assignment, with no cooldown between submissions. • Please run your code before each submission to ensure that there are no formatting errors! If there are formatting errors in your code, your code will not be graded and a submission attempt will be logged. For more information, please review the Vocareum overview below. AVLNode An AVLNode class is provided to you and will be used to represent the nodes of the tree. This file should be treated as read- only and should not be modified in any way. This AVLNode class contains getter and setter methods to access and mutate the structure of the nodes. Please make sure that you understand how this class works, as interaction with this class is crucial for this assignment. Pointer Reinforcement Since both the add() and remove() methods may change the structure of the tree, we highly recommend that you use a technique called pointer reinforcement. Although using pointer reinforcement is not required, it will help to make your code cleaner, and it'll also help greatly in future assignments if you end up taking the next course in our series! Below is a video created by our 1332 TAs, timestamped to a section on pointer reinforcement. Pointer Reinforcement Overview Balancing The tree should rotate appropriately to ensure that it is always balanced. A tree is balanced if every node's balance factor is either -1, 0, or 1. Keep in mind that you will have to update the balancing information stored in the nodes on the way back up the tree after modifying the tree; the variables are not updated automatically. NOTE: If you have completed part one of this assignment, then you should simply copy and paste your code for updateHeightAndBF, rotateLeft, rotate Right, and balance, into this assignment. Note that you may have to toggle the method visibilities to private. Comparable As stated, the data in the AVL must implement the Comparable interface. As you'll see in the files, the generic typing has been specified to require that it implements the Comparable interface. You use the interface by making a method call like data1.compareTo(data2). This will return an int, and the value tells you how data1 and data2 are in relation to each other. • If the int is positive, then datal is larger than data2. • If the int is negative, then datal is smaller than data2. . If the int is zero, then datal equals data2. Note that the returned value can be any integer in Java's int range, not just -1, 0, 1. Successor Recall that earlier in the modules you learned about the successor and predecessor of a node in a tree. As a refresher, the successor of a node, n, is the node in the tree that contains the smallest data that is larger than n's data. The predecessor of a node, n, is the node in the tree that contains the largest data that is smaller than n's data. When removing a node from an AVL that has two children, we can choose to replace the removed node with either it's successor or predecessor. For the 2- child case in remove(), you will be replacing the removed node with its successor node, NOT the predecessor node. For more details, please refer to the javadocs for remove(). Helper Methods You'll also notice that the public method stubs we've provided do not contain the parameters necessary for recursion to work, so these public methods should act as "wrapper methods" for you to use. You will have to write private recursive helper methods and call them in these wrapper methods. All of these helper methods must be private. To reiterate, do not change the method headers for the provided methods.
Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 3 steps with 1 images

Blurred answer
Knowledge Booster
Binomial Heap
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education