首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >红黑树问题

红黑树问题
EN

Stack Overflow用户
提问于 2011-04-12 08:25:12
回答 2查看 801关注 0票数 2

红黑树中的一个节点可以有一个红色和一个黑色的子节点吗?

我有下面的树,我在这里只指定了颜色。叶节点将被忽略。

代码语言:javascript
复制
                   B
           R               B
       B       B       R       R 
     R   R       R
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-04-12 08:31:42

是的,一个节点可以有不同颜色的子节点。例如,查看R-B树上the MathWorld article的最顶部的图;您可以验证它满足R-B树的所有要求,并且它的一个节点具有不同颜色的子节点。就这一点而言,您给出的例子也是如此。

票数 1
EN

Stack Overflow用户

发布于 2011-04-12 08:38:11

这里有一篇关于在Haskell中学习数据结构的背景下的读黑树的好文章。

http://scientopia.org/blogs/goodmath/2009/11/30/advanced-haskell-data-structures-red-black-trees/

它给出的R-B树标准非常清楚。红色节点的子节点必须是黑色的,但没有指定黑色节点的子节点。重要的一点是,从给定节点到到它下面的叶子的所有路径必须具有相同数量的黑色节点。看看你的树,从根部往下的每条路径都有一个黑色节点(如果算上根部就是2个),所以没问题。

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

https://stackoverflow.com/questions/5629047

复制
相关文章

相似问题

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