Create an application that will keep track of several groups of strings. Each string will be a member of exactly one group. We would like to be able to see whether two strings are in the same group as well as perform a union of two groups. Use a linked structure to represent a group of strings. Each node in the structure contains a string and a reference to another node in the group. For example, the group {“a”, “b”, “d”, “e”} is represented by the following structure:
One string in each group—”d” in our example—is in a node that has a null reference. That is, it does not reference any other node in the structure. This string is the representative string of the group.
Create the class GroupHolder to represent all of the groups and to perform operations on them. It should have the private instance variable items to hold the nodes that belong to all of the groups. The nodes within each group are linked together as described previously. Make items an instance of ArrayList whose base type is GroupNode, where GroupNode is a private inner class of GroupHolder. GroupNode has the following private instance variables:
Define the following methods in the class GroupHolder:
For example, suppose that we call addItem with each of the following strings as an argument:
“a”,”b”,”c”,”d”,”e”,”f”,”g”, and “h”. Next, let’s form groups by using these union operations:
union(“a”, “d”), union(“b”, “d”), union(“e”, “b”),
union(“h”, “f”)
We will have four groups—{“a”, “b”, “d”, “e”}, {“c”}, {“f”, “h”}, and {“g”} represented by the following structure:
The representative strings for these four groups are “d”,”c”,”f”, and “g”, respectively.
Now the operation inSameSet(“a”, “e”) would return true because both getRepresentative(“a”) and getRepresentative(“e”) return d. Also, inSameSet(“a”, “f”) would return false because getRepresentative(“a”) returns d and getRepresentative(“f”) returns f. The operation union(“a”, “f”) would make the node containing the representative string of the group to which “a” belongs—which is “d”—reference the node containing the representative string of the group to which “f” belongs, which is “f”. This reference would be represented by an arrow from “d” to “f” in the previous diagram.
Your application should create an instance of GroupHolder and allow the user to add an arbitrary number of strings, each to its own group. It should then perform an arbitrary number of union operations to form several groups. Finally, it should demonstrate the other operations.
Enjoy 24/7 customer support for any queries or concerns you have.
Phone: +1 213 3772458
Email: support@gradeessays.com