0

我正在尝试从一组预购遍历中创建一个 BST。我编写了以下代码,但无法弄清楚我在哪里犯了错误。以下代码返回值为 null 的节点。我正在使用以下方法:

10 8 4 5 14 12
我将对其进行分区(在删除凝视元素之后):8 4 5 和 14 12,(递归)。

public Node generateTree(int ar[], int low, int high) {
    if (ar.length == 0 || low > high)
        return null;

    if (low == high)
        return new Node(ar[low]);

    int partitionPoint  = findPartitionPoint(ar, low, high);

    Node root = new Node(ar[low]);

    if (partitionPoint != -1) {
        root.left = generateTree(ar, low + 1, partitionPoint);
        root.right = generateTree(ar, partitionPoint + 1, high);
    } else {
        root.left = generateTree(ar, low + 1, high);
    }
    return root;
}
private int findPartitionPoint(int ar[], int low, int high) {
    if (high >= ar.length)
        return -1;
    for (int x = low; x <= high; x++) {
        if (ar[x] > ar[low])
            return x-1;
    }

    return -1;
}
4

1 回答 1

0

我找出了罪魁祸首。问题在于我单独编写的遍历函数。这里的 Node 函数采用 int 值,但是,在 Traversal 函数中,我正在打印它的 String 值(我的 Node 类同时具有 String 和 Integer 作为键)。如此愚蠢的错误!

代码看起来是正确的。

于 2016-02-04T19:41:25.360 回答