Java递归不迭代所有顶级元素

时间:2018-06-01 07:31:28

标签: java recursion

我面临递归问题。我有一个对象,它包含自己的列表,列表中的每个对象都可以自己保存一个列表。该对象代表一棵树。

现在我想迭代所有可能的对象来找到1个特定的对象,但是我失败了。目前我的方法没有回到顶层,我不知道如何解决它。

方法:

private Object selectSpecificItem(TreeObject treeObject) {
    for (TreeObject to : treeObject.getChildren()) {
        Object data = to.getData();
        if (data instanceof PaymentOffice) {
            PaymentOffice po = (PaymentOffice) data;
            if (po.getCode().equals(getModelObject().getLocation())) {
                return to;
            }
        } else if (to.getChildren().length > 0) {
            selectSpecificItem(to);
        }
    }
    return null;
}

假设以下列表结构:

Item1
    - Item1.1
    - Item1.2
    - Item1.3
    - Item1.4
Item2
Item3

现在它迭代所有1 / 1.x项而不是2/3。我现在需要找到的项目是Item3

如何更改递归以迭代所有元素?

1 个答案:

答案 0 :(得分:6)

您忽略了递归调用返回的值。您应该检查递归调用是否返回了非null值,如果是,则返回它。

private Object selectSpecificItem(TreeObject treeObject) {
    Object result = null;
    for (TreeObject to : treeObject.getChildren()) {
        Object data = to.getData();
        if (data instanceof PaymentOffice) {
            PaymentOffice po = (PaymentOffice) data;
            if (po.getCode().equals(getModelObject().getLocation())) {
                return to;
            }
        } else if (to.getChildren().length > 0) {
            result = selectSpecificItem(to);
            if (result != null) {
                return result;
            }
        }
    }
    return result;
}

有些人喜欢在方法的最后有一个return语句。如果你是这样的人,你可以写:

private Object selectSpecificItem(TreeObject treeObject) {
    Object result = null;
    for (TreeObject to : treeObject.getChildren()) {
        Object data = to.getData();
        if (data instanceof PaymentOffice) {
            PaymentOffice po = (PaymentOffice) data;
            if (po.getCode().equals(getModelObject().getLocation())) {
                result = to;
                break;
            }
        } else if (to.getChildren().length > 0) {
            result = selectSpecificItem(to);
            if (result != null) {
                break;
            }
        }
    }
    return result;
}