用Btree算法挣扎

时间:2012-10-19 08:57:45

标签: java nullpointerexception b-tree

我尝试使用Java来实现教科书“算法入门”第3版中的算法,但没有取得多大成功。几乎每次我尝试实现它们时,都会遇到大量错误,我不确定作者本身是否尝试过实现自己的伪代码。但具体来说,在这种情况下,我遇到了Btree算法的问题。我认为问题出在B-Tree-Insert-Nonfull方法的某个地方。当我尝试运行程序时,此行会导致空指针异常:

int i = x.totalKeys - 1;

然而,这没有任何意义。在这种情况下,所有节点(如x)都在其构造函数中初始化为0,那么他的错误是如何发生的呢?我将附上以下函数:

public void bTreeInsertNonfull(Node x, Integer k)
{
    int i = x.totalKeys - 1;
    if (x.leaf || (x.children[i] == null))
    {
        while( (i >= 0) && (k < x.keys[i]) )
        {
            x.keys[i+1] = x.keys[i];
            i = i - 1;
        }
        x.keys[i+1] = k;
        x.totalKeys = x.totalKeys + 1;
    }
    else
    {
        while ( (i >= 0) && x.keys[i] != null)
        {
            if (k < x.keys[i])
            {
                i = i - 1;
            }
        }

        i = i + 1;

        if ((x.children[i] != null) && (x.children[i].totalKeys == tUpper))
        {
            bTreeSplitChild( x, i, x.children[i] );
            if (k > x.keys[i])
            {
                i = i + 1;
            }
        }
        bTreeInsertNonfull(x.children[i], k);
    }
}

1 个答案:

答案 0 :(得分:1)

阐述Alex的想法:如果你看一下算法的最后部分,有一行说:

if ((x.children[i] != null) && (x.children[i].totalKeys == tUpper))

暗示x.children[i] == null是可能的。算法的最后一行调用bTreeInsertNonfull(x.children[i], k);而不检查第一个参数是否为空。