首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何遍历Btree?

如何遍历Btree?
EN

Stack Overflow用户
提问于 2010-05-10 10:05:39
回答 2查看 7K关注 0票数 1

我有一个Btree,我正在尝试弄清楚如何遍历它,以便键按升序显示。

我所能想到的就是这可以通过一个递归函数来实现。

做这件事的伪代码是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-05-10 10:32:50

假设您有如下定义:

代码语言:javascript
复制
template <class T>
class btree_node
{
    btree_node **child;  // an array of child nodes
    T **element;  // the elements in this node

    unsigned int child_count; // the number of children
                              // the number of elements is 1 less then child_count
};

然后你需要做一些类似这样的事情:

代码语言:javascript
复制
void btree_inorder(node):
    for (int i = 0; i < node.child_count; ++i)
    {
        btree_inorder(node.child[i]);
        handle_element(node.element[i]);
    }
    btree_inorder(node.child[node.child_count-1]);
票数 2
EN

Stack Overflow用户

发布于 2018-10-22 02:07:13

代码语言:javascript
复制
void traversalBtree(struct node * root){
    int i = 1;
    if(root != NULL){
        while(i <= root->n){
            if(root->leaf == 0)
                traversalBtree(root->link[i]);
            printf("\t%d", root->key[i]);
            i++;
        }
        if(root->leaf == 0)
            traversalBtree(root->link[i]);
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2799966

复制
相关文章

相似问题

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