【发布时间】:2014-05-18 01:40:19
【问题描述】:
我在 Java 中有一个运行良好的二叉树。但我想增强节点中的数据内容。目前我可以在上面添加值,例如:
for( int i = 1; i <=10; i++ )
t.insert( new Integer( i ) );
这将添加这样的项目:
public void insert( Comparable item ) {
current = parent = grand = header;
nullNode.element = item;
...
}
这是树的格式:
private static class RedBlackNode {
// Constructors
RedBlackNode( Comparable theElement ) {
this( theElement, null, null );
}
RedBlackNode( Comparable theElement, RedBlackNode lt, RedBlackNode rt ) {
element = theElement;
left = lt;
right = rt;
color = RedBlackTree.BLACK;
}
Comparable element; // The data in the node
RedBlackNode left; // Left child
RedBlackNode right; // Right child
int color; // Color
}
为了展示树,我喜欢这样:
private void printTree( RedBlackNode t ) {
if( t != nullNode ) {
printTree( t.left );
System.out.println(t.element);
printTree( t.right );
}
}
在使用许多其他语言进行编程时,该元素将被声明为struct,而在Java 中,此sample code 被声明为Comparable,目前仅将一个元素作为整数。我的问题是,我怎样才能像结构一样使用它,以便能够像在这个伪代码中那样操作它:
System.out.println(t.element.valueInt);
System.out.println(t.element.firstNameString);
System.out.println(t.element.lastNameString);
我根据之前的一些posts 尝试了不同的语法组合,但到目前为止都没有奏效。
对于添加了 cmets 的当前代码版本,请查看Gist。
非常感谢所有建议。
【问题讨论】:
-
我认为你需要实现 Comparable 接口并覆盖 compareTo() 方法。
标签: java data-structures binary-tree comparable