406 lines
24 KiB
HTML
Raw Normal View History

2024-01-29 09:59:41 -06:00
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>TreeASDV.java</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<style type="text/css">
<!--
body {color: #a9b7c6; background-color: #2b2b2b; font-family: monospace; font-weight: bold}
pre {color: #a9b7c6; background-color: #2b2b2b; font-family: monospace; font-weight: bold}
table {color: #888888; background-color: #313335; font-family: monospace; font-weight: bold}
.string {color: #6a8759}
2024-02-02 19:19:48 -06:00
.number {color: #6897bb}
.ST2 {color: #9876aa}
.ST3 {color: #ffc66d}
.ST1 {color: #8a653b}
2024-01-29 09:59:41 -06:00
.comment {color: #808080}
.whitespace {color: #505050}
2024-02-02 19:19:48 -06:00
.ST4 {color: #9876aa; font-family: monospace; font-weight: bold; font-style: italic}
.ST6 {color: #ffc66d; font-family: monospace; font-weight: bold; font-style: italic}
2024-01-29 09:59:41 -06:00
.ST0 {color: #287bde}
.literal {color: #cc7832}
2024-02-02 19:19:48 -06:00
.ST5 {font-family: monospace; font-weight: bold; font-style: italic}
2024-01-29 09:59:41 -06:00
-->
</style>
</head>
<body>
<table width="100%"><tr><td align="center">/home/caleb/ASDV-Java/Semester 4/Assignments/ProjectTrees_CalebFontenot/src/main/java/edu/slcc/asdv/caleb/projecttrees_calebfontenot/TreeASDV.java</td></tr></table>
<pre>
<span class="comment">/*</span>
<span class="comment"> * Click </span><span class="ST0">nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt</span><span class="comment"> to change this license</span>
<span class="comment"> * Click </span><span class="ST0">nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java</span><span class="comment"> to edit this template</span>
<span class="comment"> */</span>
<span class="literal">package</span> edu.slcc.asdv.caleb.projecttrees_calebfontenot;
2024-02-02 19:19:48 -06:00
<span class="literal">import</span> java.util.ArrayList;
<span class="literal">import</span> java.util.Iterator;
2024-01-29 09:59:41 -06:00
<span class="literal">import</span> java.util.LinkedList;
2024-02-02 19:19:48 -06:00
<span class="comment">import</span> <span class="comment">java</span><span class="comment">.</span><span class="comment">util</span><span class="comment">.</span><span class="comment">ListIterator</span><span class="comment">;</span>
2024-01-29 09:59:41 -06:00
<span class="literal">import</span> java.util.Queue;
<span class="literal">import</span> java.util.Stack;
<span class="comment">/**</span>
<span class="comment"> *</span>
<span class="comment"> * </span><span class="comment">@author</span> <span class="comment">caleb</span>
2024-02-02 19:19:48 -06:00
<span class="comment"> * </span><span class="comment">@param</span> <span class="ST1">&lt;T&gt;</span>
2024-01-29 09:59:41 -06:00
<span class="comment">*/</span>
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">class</span> TreeASDV&lt;T <span class="literal">extends</span> Comparable&gt; <span class="literal">implements</span> Cloneable {
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="literal">private</span> Node&lt;T&gt; <span class="ST2">root</span>;
2024-01-29 09:59:41 -06:00
<span class="literal">class</span> Node&lt;T&gt; {
2024-02-02 19:19:48 -06:00
T <span class="ST2">data</span>;
Node&lt;T&gt; <span class="ST2">leftChild</span>;
Node&lt;T&gt; <span class="ST2">rightChild</span>;
}
@Override
<span class="literal">public</span> Object <span class="ST3">clone</span>()
{
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Cloning...</span><span class="string">&quot;</span>);
TreeASDV&lt;T&gt; clone = <span class="literal">new</span> TreeASDV&lt;T&gt;();
ArrayList&lt;T&gt; oldData = <span class="literal">this</span>.getBreadthFirstArray();
<span class="literal">for</span> (<span class="literal">int</span> i = <span class="number">0</span>; i &lt; oldData.size(); ++i) {
<span class="comment">//System.out.println(oldData.get(i));</span>
clone.insert(oldData.get(i));
}
<span class="literal">return</span> clone;
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">boolean</span> <span class="ST3">insert</span>(T t)
{
2024-01-29 09:59:41 -06:00
Node&lt;T&gt; newNode = <span class="literal">new</span> Node&lt;&gt;();
2024-02-02 19:19:48 -06:00
newNode.<span class="ST2">data</span> = t;
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (<span class="ST2">root</span> == <span class="literal">null</span>) {
<span class="ST2">root</span> = newNode;
2024-01-29 09:59:41 -06:00
<span class="literal">return</span> <span class="literal">true</span>;
}
2024-02-02 19:19:48 -06:00
Node&lt;T&gt; current = <span class="ST2">root</span>;
2024-01-29 09:59:41 -06:00
Node&lt;T&gt; parent = <span class="literal">null</span>;
<span class="literal">while</span> (current != <span class="literal">null</span>) {
parent = current;
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (t.compareTo(current.<span class="ST2">data</span>) &gt;= <span class="number">0</span>) {
current = current.<span class="ST2">rightChild</span>;
2024-01-29 09:59:41 -06:00
} <span class="literal">else</span> {
2024-02-02 19:19:48 -06:00
current = current.<span class="ST2">leftChild</span>;
2024-01-29 09:59:41 -06:00
}
}
<span class="comment">// At this point, &#39;parent&#39; is the node where the new node should be inserted as a child</span>
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (t.compareTo(parent.<span class="ST2">data</span>) &gt;= <span class="number">0</span>) {
parent.<span class="ST2">rightChild</span> = newNode;
2024-01-29 09:59:41 -06:00
} <span class="literal">else</span> {
2024-02-02 19:19:48 -06:00
parent.<span class="ST2">leftChild</span> = newNode;
2024-01-29 09:59:41 -06:00
}
<span class="literal">return</span> <span class="literal">true</span>;
}
2024-02-02 19:19:48 -06:00
<span class="literal">private</span> <span class="literal">void</span> <span class="comment">inOrder</span>(Node&lt;T&gt; p)
{
2024-01-29 09:59:41 -06:00
<span class="literal">if</span> (p == <span class="literal">null</span>) {
<span class="literal">return</span>;
}
2024-02-02 19:19:48 -06:00
inOrder(p.<span class="ST2">leftChild</span>);
System.<span class="ST4">out</span>.print(p.<span class="ST2">data</span> + <span class="string">&quot;</span> <span class="string">&quot;</span>);
inOrder(p.<span class="ST2">rightChild</span>);
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> Node&lt;T&gt; <span class="ST3">findNode</span>(T t)
{
Node&lt;T&gt; currentNode = <span class="ST2">root</span>;
2024-01-29 09:59:41 -06:00
<span class="literal">while</span> (currentNode != <span class="literal">null</span>) {
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (t.compareTo(currentNode.<span class="ST2">data</span>) == <span class="number">0</span>) {
2024-01-29 09:59:41 -06:00
<span class="literal">return</span> currentNode;
2024-02-02 19:19:48 -06:00
} <span class="literal">else</span> <span class="literal">if</span> (t.compareTo(currentNode.<span class="ST2">data</span>) &gt; <span class="number">0</span>) {
currentNode = currentNode.<span class="ST2">rightChild</span>;
2024-01-29 09:59:41 -06:00
} <span class="literal">else</span> {
2024-02-02 19:19:48 -06:00
currentNode = currentNode.<span class="ST2">leftChild</span>;
2024-01-29 09:59:41 -06:00
}
}
<span class="literal">return</span> <span class="literal">null</span>;
}
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">boolean</span> <span class="ST3">remove</span>(T t) {
<span class="comment">// Initialize parent and current nodes for traversal</span>
Node&lt;T&gt; parent = <span class="literal">null</span>;
Node&lt;T&gt; current = <span class="ST2">root</span>;
<span class="comment">// Search for the node to be removed</span>
<span class="literal">while</span> (current != <span class="literal">null</span> &amp;&amp; !current.<span class="ST2">data</span>.equals(t)) {
parent = current;
<span class="literal">if</span> (t.compareTo(current.<span class="ST2">data</span>) &gt; <span class="number">0</span>) {
current = current.<span class="ST2">rightChild</span>;
} <span class="literal">else</span> {
current = current.<span class="ST2">leftChild</span>;
}
}
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="comment">// If node not found, return false</span>
<span class="literal">if</span> (current == <span class="literal">null</span>) {
<span class="literal">return</span> <span class="literal">false</span>;
}
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="comment">// Case 1: Node with no children</span>
<span class="literal">if</span> (current.<span class="ST2">leftChild</span> == <span class="literal">null</span> &amp;&amp; current.<span class="ST2">rightChild</span> == <span class="literal">null</span>) {
<span class="literal">if</span> (current == <span class="ST2">root</span>) {
<span class="ST2">root</span> = <span class="literal">null</span>; <span class="comment">// Removing root node</span>
} <span class="literal">else</span> <span class="literal">if</span> (parent.<span class="ST2">leftChild</span> == current) {
parent.<span class="ST2">leftChild</span> = <span class="literal">null</span>; <span class="comment">// Removing a left child</span>
} <span class="literal">else</span> {
parent.<span class="ST2">rightChild</span> = <span class="literal">null</span>; <span class="comment">// Removing a right child</span>
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
} <span class="comment">// Case 2: Node with one child</span>
<span class="literal">else</span> <span class="literal">if</span> (current.<span class="ST2">leftChild</span> == <span class="literal">null</span> || current.<span class="ST2">rightChild</span> == <span class="literal">null</span>) {
Node&lt;T&gt; child = (current.<span class="ST2">leftChild</span> != <span class="literal">null</span>) ? current.<span class="ST2">leftChild</span> : current.<span class="ST2">rightChild</span>;
<span class="literal">if</span> (current == <span class="ST2">root</span>) {
<span class="ST2">root</span> = child; <span class="comment">// Replace root with its child</span>
} <span class="literal">else</span> <span class="literal">if</span> (parent.<span class="ST2">leftChild</span> == current) {
parent.<span class="ST2">leftChild</span> = child; <span class="comment">// Replace parent&#39;s left child with the node&#39;s child</span>
} <span class="literal">else</span> {
parent.<span class="ST2">rightChild</span> = child; <span class="comment">// Replace parent&#39;s right child with the node&#39;s child</span>
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
} <span class="comment">// Case 3: Node with two children</span>
<span class="literal">else</span> {
Node&lt;T&gt; successorParent = current;
Node&lt;T&gt; successor = current.<span class="ST2">rightChild</span>;
<span class="literal">while</span> (successor.<span class="ST2">leftChild</span> != <span class="literal">null</span>) {
successorParent = successor;
successor = successor.<span class="ST2">leftChild</span>;
}
current.<span class="ST2">data</span> = successor.<span class="ST2">data</span>; <span class="comment">// Replace data with successor&#39;s data</span>
<span class="literal">if</span> (successorParent == current) {
successorParent.<span class="ST2">rightChild</span> = successor.<span class="ST2">rightChild</span>;
} <span class="literal">else</span> {
successorParent.<span class="ST2">leftChild</span> = successor.<span class="ST2">rightChild</span>;
2024-01-29 09:59:41 -06:00
}
}
2024-02-02 19:19:48 -06:00
<span class="literal">return</span> <span class="literal">true</span>;
}
2024-01-29 09:59:41 -06:00
<span class="comment">// Helper method to find in-order successor of a node</span>
2024-02-02 19:19:48 -06:00
<span class="literal">private</span> Node&lt;T&gt; <span class="comment">getSuccessor</span>(Node&lt;T&gt; node)
{
Node&lt;T&gt; current = node.<span class="ST2">rightChild</span>;
2024-01-29 09:59:41 -06:00
Node&lt;T&gt; successorParent = node;
Node&lt;T&gt; successor = node;
<span class="comment">// Find the leftmost node in the right subtree (in-order successor)</span>
<span class="literal">while</span> (current != <span class="literal">null</span>) {
successorParent = successor;
successor = current;
2024-02-02 19:19:48 -06:00
current = current.<span class="ST2">leftChild</span>;
2024-01-29 09:59:41 -06:00
}
<span class="comment">// If the successor is not the right child of the node to be removed,</span>
<span class="comment">// adjust the successor&#39;s parent&#39;s leftChild reference</span>
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (successor != node.<span class="ST2">rightChild</span>) {
successorParent.<span class="ST2">leftChild</span> = successor.<span class="ST2">rightChild</span>;
successor.<span class="ST2">rightChild</span> = node.<span class="ST2">rightChild</span>;
2024-01-29 09:59:41 -06:00
}
<span class="literal">return</span> successor;
}
2024-02-02 19:19:48 -06:00
<span class="comment">// Inorder ListIterator</span>
<span class="literal">public</span> Iterator&lt;T&gt; <span class="ST3">listIterator</span>()
{
<span class="literal">return</span> <span class="literal">new</span> InorderIterator();
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">private</span> <span class="literal">class</span> InorderIterator <span class="literal">implements</span> Iterator&lt;T&gt; {
<span class="literal">private</span> Stack&lt;Node&lt;T&gt;&gt; <span class="ST2">stack</span>;
<span class="literal">public</span> InorderIterator()
{
<span class="ST2">stack</span> = <span class="literal">new</span> Stack&lt;&gt;();
pushLeft(<span class="ST2">r</span><span class="ST2">oot</span>);
}
<span class="literal">private</span> <span class="literal">void</span> <span class="ST3">pushLeft</span>(Node&lt;T&gt; node)
{
<span class="literal">while</span> (node != <span class="literal">null</span>) {
<span class="ST2">stack</span>.push(node);
node = node.<span class="ST2">leftChild</span>;
}
}
@Override
<span class="literal">public</span> <span class="literal">boolean</span> <span class="ST3">hasNext</span>()
{
<span class="literal">return</span> !<span class="ST2">stack</span>.isEmpty();
}
@Override
<span class="literal">public</span> T <span class="ST3">next</span>()
{
<span class="literal">if</span> (!hasNext()) {
<span class="literal">throw</span> <span class="literal">new</span> java.util.NoSuchElementException();
}
Node&lt;T&gt; current = <span class="ST2">stack</span>.pop();
pushLeft(current.<span class="ST2">rightChild</span>);
<span class="literal">return</span> current.<span class="ST2">data</span>;
}
@Override
<span class="literal">public</span> <span class="literal">void</span> <span class="ST3">remove</span>()
{
<span class="literal">throw</span> <span class="literal">new</span> UnsupportedOperationException();
}
}
<span class="literal">public</span> ArrayList&lt;T&gt; <span class="ST3">getBreadthFirstArray</span>()
{
ArrayList&lt;T&gt; returnArray = <span class="literal">new</span> ArrayList&lt;T&gt;();
<span class="literal">if</span> (<span class="ST2">root</span> == <span class="literal">null</span>) {
<span class="literal">return</span> returnArray;
}
Queue&lt;Node&lt;T&gt;&gt; queue = <span class="literal">new</span> LinkedList&lt;&gt;();
queue.offer(<span class="ST2">r</span><span class="ST2">oot</span>);
<span class="literal">while</span> (!queue.isEmpty()) {
Node&lt;T&gt; current = queue.poll();
returnArray.add(current.<span class="ST2">data</span>);
<span class="literal">if</span> (current.<span class="ST2">leftChild</span> != <span class="literal">null</span>) {
queue.offer(current.<span class="ST2">leftChild</span>);
}
<span class="literal">if</span> (current.<span class="ST2">rightChild</span> != <span class="literal">null</span>) {
queue.offer(current.<span class="ST2">rightChild</span>);
}
}
<span class="literal">return</span> returnArray;
}
<span class="literal">public</span> <span class="literal">void</span> <span class="ST3">breadthFirstTraversal</span>()
{
<span class="literal">if</span> (<span class="ST2">root</span> == <span class="literal">null</span>) {
2024-01-29 09:59:41 -06:00
<span class="literal">return</span>;
}
Queue&lt;Node&lt;T&gt;&gt; queue = <span class="literal">new</span> LinkedList&lt;&gt;();
2024-02-02 19:19:48 -06:00
queue.offer(<span class="ST2">r</span><span class="ST2">oot</span>);
2024-01-29 09:59:41 -06:00
<span class="literal">while</span> (!queue.isEmpty()) {
Node&lt;T&gt; current = queue.poll();
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.print(current.<span class="ST2">data</span> + <span class="string">&quot;</span> <span class="string">&quot;</span>);
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (current.<span class="ST2">leftChild</span> != <span class="literal">null</span>) {
queue.offer(current.<span class="ST2">leftChild</span>);
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">if</span> (current.<span class="ST2">rightChild</span> != <span class="literal">null</span>) {
queue.offer(current.<span class="ST2">rightChild</span>);
2024-01-29 09:59:41 -06:00
}
}
}
2024-02-02 19:19:48 -06:00
@Override
<span class="literal">public</span> <span class="literal">boolean</span> <span class="ST3">equals</span>(Object obj) {
<span class="literal">return</span> <span class="literal">this</span>.getBreadthFirstArray().equals(((TreeASDV) obj).getBreadthFirstArray());
}
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">int</span> <span class="ST3">height</span>()
{
<span class="literal">return</span> calculateHeight(<span class="ST2">r</span><span class="ST2">oot</span>);
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">private</span> <span class="literal">int</span> <span class="ST3">calculateHeight</span>(Node&lt;T&gt; node)
{
2024-01-29 09:59:41 -06:00
<span class="literal">if</span> (node == <span class="literal">null</span>) {
<span class="literal">return</span> <span class="number">0</span>;
}
2024-02-02 19:19:48 -06:00
<span class="literal">int</span> leftHeight = calculateHeight(node.<span class="ST2">leftChild</span>);
<span class="literal">int</span> rightHeight = calculateHeight(node.<span class="ST2">rightChild</span>);
2024-01-29 09:59:41 -06:00
2024-02-02 19:19:48 -06:00
<span class="literal">return</span> <span class="number">1</span> + Math.<span class="ST5">max</span>(leftHeight, rightHeight);
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">boolean</span> <span class="ST3">isFullBST</span>()
{
2024-01-29 09:59:41 -06:00
<span class="literal">int</span> height = height();
2024-02-02 19:19:48 -06:00
<span class="literal">int</span> nodeCount = countNodes(<span class="ST2">r</span><span class="ST2">oot</span>);
2024-01-29 09:59:41 -06:00
<span class="literal">return</span> nodeCount == (<span class="number">1</span> &lt;&lt; height) - <span class="number">1</span>; <span class="comment">// Formula for full binary tree</span>
}
2024-02-02 19:19:48 -06:00
<span class="literal">private</span> <span class="literal">int</span> <span class="ST3">countNodes</span>(Node&lt;T&gt; node)
{
2024-01-29 09:59:41 -06:00
<span class="literal">if</span> (node == <span class="literal">null</span>) {
<span class="literal">return</span> <span class="number">0</span>;
}
2024-02-02 19:19:48 -06:00
<span class="literal">return</span> <span class="number">1</span> + countNodes(node.<span class="ST2">leftChild</span>) + countNodes(node.<span class="ST2">rightChild</span>);
2024-01-29 09:59:41 -06:00
}
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">void</span> <span class="ST3">inOrder</span>()
{
<span class="literal">if</span> (<span class="ST2">root</span> == <span class="literal">null</span>) {
2024-01-29 09:59:41 -06:00
<span class="literal">return</span>;
}
Stack&lt;Node&lt;T&gt;&gt; stack = <span class="literal">new</span> Stack&lt;&gt;();
2024-02-02 19:19:48 -06:00
Node&lt;T&gt; current = <span class="ST2">root</span>;
2024-01-29 09:59:41 -06:00
<span class="literal">while</span> (current != <span class="literal">null</span> || !stack.isEmpty()) {
<span class="literal">while</span> (current != <span class="literal">null</span>) {
stack.push(current);
2024-02-02 19:19:48 -06:00
current = current.<span class="ST2">leftChild</span>;
2024-01-29 09:59:41 -06:00
}
current = stack.pop();
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.print(current.<span class="ST2">data</span> + <span class="string">&quot;</span> <span class="string">&quot;</span>);
current = current.<span class="ST2">rightChild</span>;
2024-01-29 09:59:41 -06:00
}
}
2024-02-02 19:19:48 -06:00
<span class="literal">public</span> <span class="literal">static</span> <span class="literal">void</span> <span class="ST6">main</span>(String[] args) <span class="literal">throws</span> CloneNotSupportedException
{
2024-01-29 09:59:41 -06:00
TreeASDV&lt;Integer&gt; tree = <span class="literal">new</span> TreeASDV&lt;&gt;();
<span class="comment">// Insert some elements into the tree</span>
tree.insert(<span class="number">5</span>);
tree.insert(<span class="number">3</span>);
tree.insert(<span class="number">7</span>);
tree.insert(<span class="number">2</span>);
tree.insert(<span class="number">4</span>);
tree.insert(<span class="number">6</span>);
tree.insert(<span class="number">8</span>);
<span class="comment">// Test breadth-first traversal</span>
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Breadth-First Traversal:</span><span class="string">&quot;</span>);
2024-01-29 09:59:41 -06:00
tree.breadthFirstTraversal();
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.println();
2024-01-29 09:59:41 -06:00
<span class="comment">// Test height calculation</span>
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Height of the tree: </span><span class="string">&quot;</span> + tree.height());
2024-01-29 09:59:41 -06:00
<span class="comment">// Test if the tree is a full binary tree</span>
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Is the tree a full binary tree? </span><span class="string">&quot;</span> + tree.isFullBST());
2024-01-29 09:59:41 -06:00
<span class="comment">// Test inorder traversal without recursion</span>
2024-02-02 19:19:48 -06:00
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Inorder Traversal without Recursion:</span><span class="string">&quot;</span>);
tree.inOrder();
System.<span class="ST4">out</span>.println();
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">array list from breadth traversal</span><span class="string">&quot;</span>);
System.<span class="ST4">out</span>.println(tree.getBreadthFirstArray());
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Cloned Tree:</span><span class="string">&quot;</span>);
TreeASDV&lt;Integer&gt; clonedTree = (TreeASDV&lt;Integer&gt;) tree.clone();
clonedTree.breadthFirstTraversal();
System.<span class="ST4">out</span>.println();
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Does the original tree and the clone tree equal? </span><span class="string">&quot;</span> + (tree.equals(clonedTree) ? <span class="string">&quot;</span><span class="string">yes</span><span class="string">&quot;</span> : <span class="string">&quot;</span><span class="string">no</span><span class="string">&quot;</span>) );
tree.insert(<span class="number">3</span><span class="number">000000</span>);
System.<span class="ST4">out</span>.println(<span class="string">&quot;</span><span class="string">Does the original tree and the clone tree equal? </span><span class="string">&quot;</span> + (tree.equals(clonedTree) ? <span class="string">&quot;</span><span class="string">yes</span><span class="string">&quot;</span> : <span class="string">&quot;</span><span class="string">no</span><span class="string">&quot;</span>) );
tree.remove(<span class="number">5</span>);
tree.breadthFirstTraversal();
2024-01-29 09:59:41 -06:00
}
}
</pre></body>
</html>