222 lines
5.4 KiB
Java
Raw Normal View History

/*
* Copyright (c) 2002, 2018, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package gc.gctests.JumbleGC;
import java.util.Vector ;
class treeNode {
static int memorySinkSize = 100;
int info;
treeNode left;
treeNode right;
int [] memory_sink;
public treeNode(int info) {
this.info = info;
memory_sink = new int[memorySinkSize];
}
}
public class Tree {
private treeNode TreeRoot; // root of Tree
private int elementCount; // number of elements in Tree
Vector TreeValues; // all the nodal values in the tree
// duplicated in this array.
private int TreeValueIndex; // Where to store next Tree value
Tree(int TreeSize) { TreeValues = new Vector(TreeSize); }
synchronized void addElement(int o) {
treeNode p,q;
treeNode newnode = new treeNode(o);
p = TreeRoot;
q = null;
while(p != null){
q = p;
if(newnode.info <= p.info)
p = p.left;
else
p = p.right;
}
if ( q == null ){
TreeRoot = newnode;
return;
}
if (newnode.info <= q.info )
q.left = newnode;
else
q.right = newnode;
elementCount++;
TreeValues.addElement(new Integer(o));
}
int getTreeValue(int index) {
Integer num;
num = (Integer) TreeValues.elementAt(index);
TreeValues.removeElementAt(index);
return num.intValue();
}
int vectorSize(){ return TreeValues.size(); }
synchronized void PrettyPrint(){
Print(TreeRoot, "");
}
private void Print( treeNode root, String indent) {
if(root == null){
return;
}
Print(root.right, indent + " ");
System.out.println(indent + root.info);
Print(root.left, indent + " ");
}
synchronized int getNodeNumber(){return elementCount; }
synchronized private treeNode findNode(int o) {
treeNode p, q;
p = TreeRoot;
while(p != null && p.info != o){
q = p;
if (o < p.info )
p = p.left;
else if(o > p.info)
p = p.right;
}
return p;
}
// destroy subtree rooted at treeNode containing int o
// creating a subtree of garbage rooted at treeNode containing int o
void destroySubTree(int o) {
treeNode p,q;
// find treeNode containing p.
p = TreeRoot;
q = null;
while(p != null && p.info != o){
q = p;
if (o < p.info )
p = p.left;
else if(o > p.info)
p = p.right;
}
if (p == null){ // couldnt find treeNode
return;
}
// decrease elementCount of tree by the number of treeNodes
// in sub-tree rooted at p
elementCount -= getCount(p);
if (q == null){ // destroy the whole tree
TreeRoot = null;
return;
}
if (p.info > q.info ) // deleting right child
q.right = null;
else
q.left = null;
}
synchronized void deleteElement(int o){
treeNode p,q;
treeNode rc, sub_node, leftmost, leftmost_parent,s;
p = TreeRoot;
q = null;
sub_node = null;
while(p != null && p.info != o){
q = p;
if (o < p.info )
p = p.left;
else if(o > p.info)
p = p.right;
}
if ( p == null) // couldnt find treeNode
return;
rc = p.right;
if (rc == null){
sub_node = p.left;
} else if (rc.left == null) {
rc.left = p.left;
sub_node = p.right;
}else if ( rc.left != null && rc.right != null) {
s = rc;
leftmost_parent = null;
leftmost = null;
while ( s != null){
leftmost_parent = leftmost;
leftmost = s;
s = s.left;
}
leftmost_parent.left = leftmost.right;
leftmost.left = p.left;
leftmost.right= p.right;
sub_node = leftmost;
}
if ( q == null ){
TreeRoot = sub_node;
return;
}
if (p.info > q.info ) // deleting right child
q.right = sub_node;
else
q.left = sub_node;
return;
}
private int getCount( treeNode root) {
if (root == null )
return 0;
if (root.left == null && root.right == null)
return 1;
else
return getCount(root.left) + getCount(root.right) + 1;
}
}