java n元树深度

  • 本文关键字:深度 java java tree
  • 更新时间 :
  • 英文 :


这是我的树节点类:

public class Generalization extends Class_object {
private List<Generalization> superClasses;
private List<Generalization> subClasses;
public boolean isRoot() {
    return superClasses.size() == 0;
}
public boolean isLeaf() {
    return subClasses.size() == 0;
}
// path length to root
public String getDIT() {
    return Integer.toString(recuDIT(this));
}
public int recuDIT(Generalization g) {
    if (g.isRoot())
        return 0;
    else {
        int maxLength = 0;
        for (Generalization gen : superClasses) {
            maxLength = Math.max(maxLength, recuDIT(gen));
        }
        return maxLength + 1;
    }
}
// path length to leaf
public String getCLD() {
    return Integer.toString(recuCLD(this));
}
public int recuCLD(Generalization g) {
    if (g.isLeaf())
        return 0;
    else {
        int maxLength = 0;
        for (Generalization gen : subClasses) {
            maxLength = Math.max(maxLength, recuCLD(gen));
        }
        return maxLength + 1;
    }
}
}

每个节点都有其父节点和子节点。但当我执行程序时,它在递归函数(CLD和DIT)中都会给我stackoverflow错误。有人能告诉我为什么它们无限循环吗?谢谢

public class Generalization {
    private List<Generalization> superClasses;
    private List<Generalization> subClasses;
    public Generalization(){
        superClasses = new ArrayList<Generalization>();
        subClasses = new ArrayList<Generalization>();
    }
    public boolean isRoot() {
        return superClasses.size() == 0;
    }
    public boolean isLeaf() {
        return subClasses.size() == 0;
    }
    // path length to root
    public String getDIT() {
        return Integer.toString(recuDIT(this));
    }
    public int recuDIT(Generalization g) {
        if (g.isRoot())
            return 0;
        else {
            int maxLength = 0;
            for(int i = 0 ; i < g.superClasses.size(); i++){
                maxLength = Math.max(maxLength, recuDIT(g.superClasses.get(i)));
            }
            return maxLength + 1;
        }
    }
    // path length to leaf
    public String getCLD() {
        return Integer.toString(recuCLD(this));
    }
    public int recuCLD(Generalization g) {
        if (g.isLeaf())
            return 0;
        else {
            int maxLength = 0;
            for(int i = 0 ; i < g.subClasses.size(); i++){
            maxLength = Math.max(maxLength, recuCLD(g.subClasses.get(i)));
            }
            return maxLength + 1;
        }
    }
public static void main(String[] args){
    Generalization root = new Generalization();
    Generalization ch1 = new Generalization();
    Generalization ch2 = new Generalization();
    root.subClasses.add(ch1);
    root.subClasses.add(ch2);
    Generalization gc1 = new Generalization();
    Generalization gc2 = new Generalization();
    Generalization gc3 = new Generalization();
    ch2.superClasses.add(root); 
    ch2.subClasses.add(gc1);
    ch2.subClasses.add(gc2);
    ch1.subClasses.add(gc3);
    ch1.superClasses.add(root);
    Generalization ggc1 = new Generalization();
    gc3.subClasses.add(ggc1);
    gc3.superClasses.add(ch1);
    gc2.superClasses.add(ch2);
    gc1.superClasses.add(ch2);
    ggc1.superClasses.add(gc3);
    System.out.println(ggc1.getDIT());
    System.out.println(root.getCLD());

}
}

在不知道我是否正确设置了树或真的测试了那么多的情况下,这对我来说很有效。主要问题是你在方法中使用了类recDIT/CLD,而不是泛化对象g。因此,您一直在递归地循环遍历同一个列表,而没有从第一个索引开始。我还将for each循环更改为for循环,因为这样更容易查看和调试。

除此之外,这给了我3根的长度和叶的长度,我认为这是正确的。

最新更新