0

我很难理解为什么这个类不起作用。这是数据结构课程作业的一部分(编辑:作业的截止日期已经过去,我只是想弄清楚......)。该节点是基于 BST 构建的 AVL 树的一部分,我选择实现它的方式是在我的 Node 类中创建方法来查找平衡因子和高度。

该类的结构如下:

public class Node<T extends Comparable<? super T>> {

public T data;
public Node left;
public Node right;

public Node(T IN) {
    data = IN;
}

public Node(T IN, Node L, Node R) {
    this(IN);
    left = L;
    right = R;
}

@Override
public String toString() {
    return data.toString();
}

@Override
public Node clone() {
    return new Node(this.data) ;
}

public int getHeight() {
    return getHeight(this) ;
}

public int getBF() {

        //Calculate BF
        int balanceFactor = 0;
        if (right != null && left != null)
            balanceFactor = getHeight(right) - getHeight(left);
        else if (left != null) {
            balanceFactor = 0 - getHeight(left) ;
        }
        else if (right != null) {
            balanceFactor = getHeight(right) ;
        }
        else
            balanceFactor = 0 ;
        return balanceFactor ;
}

private int getHeight(Node p) {
    if (p.left == null && p.right == null ) {
        return 0 ;
    }
    else if (p.left != null && p.right != null) {
        return 1 + max(p.left.getHeight(), p.right.getHeight());
    }
    else if (p.left != null) {
        return 1 + p.left.getHeight() ;
    }
    else if (p.right != null) {
        return 1 + p.right.getHeight() ;
    }
    else {
        return 0;
    }
}

private int max(int x, int y) {
    if (x >= y) {
        return x;
    } else {
        return y;
    }
}

}

调用该方法的函数是:

@Override
public boolean insert(T el) {
    boolean test = super.insert(el) ;
    if (test) {
        return checkBalance(root) ;
    }
    else
        return false ;
}

我收到的例外是重复:

Exception in thread "main" java.lang.StackOverflowError
at Node.getHeight(Node.java:54)
at Node.getHeight(Node.java:33)
at Node.getHeight(Node.java:58)
4

2 回答 2

4

我建议你的树要么变形,要么真的很大。代码似乎没有问题。

如果您的树以这样的方式变形,以至于您Node在同一棵树中插入了两次,那么此代码将中断。

补充- 你吃的堆栈比你需要的多 - 替换p.left.getHeight()getHeight(p.left)etc. 将避免每次递归推送一个堆栈。如果您的问题只是大树,那么这可能会让您陷入困境,但这只会推迟问题。

于 2013-04-02T10:29:23.503 回答
2

通过查看这两种 getHeight 方法,您似乎没有树而是循环图。您应该从仅包含根的树开始测试,然后添加节点,直到观察到无限递归。您可能在重新平衡树的函数中有错误。

编辑:并且您应该将属性(至少左右)设为私有。

于 2013-04-02T10:28:52.720 回答