V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
helloworld12
V2EX  ›  算法

B 树根节点,是否也同时可以当做叶子节点

  •  
  •   helloworld12 · 2017-03-05 19:18:46 +08:00 · 3604 次点击
    这是一个创建于 2581 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如题。 B 树的根节点,是否同时可以当做叶节点,还是必须有中间节点

    我准备用 golang 实现一个 B 树
    我先前是假设根节点,也可以当做叶子节点,然后在要分裂的时候就懵逼了,不知道该怎么分裂出中间节点

    type BTNode struct {
        keys   []int
        vals   []interface{}
        isLeaf  bool
        parentNode *BTNode
    }
    
    1 条回复    2017-03-05 20:04:37 +08:00
    helloworld12
        1
    helloworld12  
    OP
       2017-03-05 20:04:37 +08:00
    看 btree 实现的时候,有个不懂得,为什么 [New(2) 得到的是一个 234 树]( https://github.com/google/btree/blob/master/btree.go#L119-L125) 不应该是 2 个叉都是 2 个 key3 个子元素吗?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2581 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 15:40 · PVG 23:40 · LAX 08:40 · JFK 11:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.