首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >纠结于Btree算法

纠结于Btree算法
EN

Stack Overflow用户
提问于 2012-10-19 16:57:45
回答 1查看 529关注 0票数 1

我尝试过使用Java来实现教科书《算法导论》第三版中的算法,但没有太多成功。几乎每次我尝试实现它们时,我都会遇到许多错误,以至于我不确定作者自己是否尝试过实现他们自己的伪代码。但具体地说,在这种情况下,我遇到了Btree算法的问题。我认为问题出在B-Tree-Insert-Nonfull方法中。当我尝试运行程序时,这一行导致了一个空指针异常:

int i= x.totalKeys - 1;

然而,这没有任何意义。所有节点,比如本例中的x,在其构造函数中都被初始化为0,那么他的错误是如何发生的呢?我将把下面的函数封闭起来:

代码语言:javascript
复制
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);
    }
}
EN

回答 1

Stack Overflow用户

发布于 2012-10-19 17:07:42

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

代码语言:javascript
复制
if ((x.children[i] != null) && (x.children[i].totalKeys == tUpper))

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12970733

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档