免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: ldap
打印 上一主题 下一主题

BTREE算法C语言实现 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2007-12-07 15:04 |只看该作者

回复 #10 ldap 的帖子

void init_btree32_i_walker(walker *cc)
{
    if (cc == NULL) {
        return;
    }

    cc->pos = 0;
    cc->out = WALKER_OUT_INIT;
    cc->beg = 0;
}

bnode32_i *walker_btree32_i(bnode32_i *node, int16 pos, void **index, int32 *key, walker *cc)
{
    int16    i;

    Assert(key != NULL);
    Assert(pos >= 0);
    Assert(cc != NULL);

    if (node == NULL) {
        return NULL;
    }

    /* enter last out scene */
    if (cc->out == WALKER_OUT_LEAF)
        goto leaf;
    if (cc->out == WALKER_OUT_ROOT)
        goto start;

    cc->pos = pos;

start:
    /* trace to bottom */
    for(;;) {
        if (node->child[0] != NULL) {
            node = node->child[cc->pos];
            cc->pos = 0;
            continue;
        }
        break;
    }

leaf:
    /* current node must be leaf node */
&nbsp;&nbsp;&nbsp;&nbsp;for (i = cc->beg; i < node->num; i++) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*key = node->key[i];
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*index = node->index[i];
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cc->out = WALKER_OUT_LEAF;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cc->beg = i + 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return node;
&nbsp;&nbsp;&nbsp;&nbsp;}

prev:
&nbsp;&nbsp;&nbsp;&nbsp;/* output the last key of root */
&nbsp;&nbsp;&nbsp;&nbsp;if (node->parent == NULL) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return NULL;
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;/* output the key of previus middle node */
&nbsp;&nbsp;&nbsp;&nbsp;if (node->pos < node->parent->num) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*key = node->parent->key[node->pos];
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;*index = node->parent->index[node->pos];

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cc->pos = node->pos + 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;node = node->parent;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cc->out = WALKER_OUT_ROOT;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cc->beg = 0;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return node;
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;/* have output the all key in the middle node,*/
&nbsp;&nbsp;&nbsp;&nbsp;/* so must output the up node.                */

&nbsp;&nbsp;&nbsp;&nbsp;node = node->parent;
&nbsp;&nbsp;&nbsp;&nbsp;goto prev;
}

论坛徽章:
0
12 [报告]
发表于 2007-12-07 15:05 |只看该作者

回复 #11 ldap 的帖子

void free_btree32_i(bnode32_i *node)
{
&nbsp;&nbsp;&nbsp;&nbsp;int16&nbsp;&nbsp;&nbsp;&nbsp;pos = 0;
&nbsp;&nbsp;&nbsp;&nbsp;bnode32_i&nbsp;&nbsp;&nbsp;&nbsp;*freenode;

&nbsp;&nbsp;&nbsp;&nbsp;if (node == NULL) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return;
&nbsp;&nbsp;&nbsp;&nbsp;}

start:
&nbsp;&nbsp;&nbsp;&nbsp;/* trace to bottom */
&nbsp;&nbsp;&nbsp;&nbsp;for(;;) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (node->child[0] != NULL) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;node = node->child[pos];
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;pos = 0;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;continue;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;break;
&nbsp;&nbsp;&nbsp;&nbsp;}
prev:
&nbsp;&nbsp;&nbsp;&nbsp;if (node->parent == NULL) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;/* free root */
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;node = btree_free(node);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return;
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;if (node->pos < node->parent->num) {

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;/* free child */

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;pos = node->pos + 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;freenode = node;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;node = node->parent;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;freenode = btree_free(freenode);

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;goto start;
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;/* free right node */
&nbsp;&nbsp;&nbsp;&nbsp;freenode = node;
&nbsp;&nbsp;&nbsp;&nbsp;node = node->parent;
&nbsp;&nbsp;&nbsp;&nbsp;freenode = btree_free(freenode);

&nbsp;&nbsp;&nbsp;&nbsp;goto prev;
}

bnode32_i *root_btree32_i(bnode32_i *node)
{
&nbsp;&nbsp;&nbsp;&nbsp;Assert(node != NULL);

&nbsp;&nbsp;&nbsp;&nbsp;for(;;) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (node->parent != NULL) {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;node = node->parent;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;else {
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;break;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;return node;
}

论坛徽章:
0
13 [报告]
发表于 2007-12-07 15:11 |只看该作者
呵呵,竟然有人说自己的代码完美~~~哈哈

openbase..........嘿嘿~~明白人都知道是怎么回事。

算了,看LZ这么亢奋~~

论坛徽章:
0
14 [报告]
发表于 2007-12-07 15:14 |只看该作者
很久不见ldap了,现在在哪儿高就呢?~~

论坛徽章:
0
15 [报告]
发表于 2007-12-07 15:20 |只看该作者
LZ能否把代码全部打个包上传啊。。

论坛徽章:
0
16 [报告]
发表于 2007-12-07 16:06 |只看该作者
算了,还是把完美去掉吧,其实明白人是知道怎么回事,但是切忌,瘦死的骆驼比马大。

论坛徽章:
0
17 [报告]
发表于 2007-12-07 16:11 |只看该作者
原帖由 Cu_fans 于 2007-12-7 15:20 发表
LZ能否把代码全部打个包上传啊。。



会的,我得把一些不相关的东西和瓜葛都去掉,然后再打包上传,这样也方便使用。

论坛徽章:
0
18 [报告]
发表于 2007-12-07 16:16 |只看该作者
前辈别介意~~说笑而已,没有冒犯的意思啊~另外提醒一句,把注释删掉,泄密了!

[ 本帖最后由 anthony1983 于 2007-12-7 16:22 编辑 ]

论坛徽章:
0
19 [报告]
发表于 2007-12-07 16:45 |只看该作者
占个坑。。。。。。。。

多谢LZ!

论坛徽章:
0
20 [报告]
发表于 2007-12-09 21:37 |只看该作者
看头像就知道谁了,我旁边的旁边的旁边,哈哈哈
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP