| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 504 人关注过本帖
标题:遍历二叉树出了问题!
只看楼主 加入收藏
Benthy2
Rank: 1
等 级:新手上路
帖 子:25
专家分:7
注 册:2011-12-16
结帖率:66.67%
收藏
已结贴  问题点数:10 回复次数:2 
遍历二叉树出了问题!
编译过不去!
void myprintf(node *Tree)
{
    printf("\n%s,%d\n",Tree->data.ch,Tree->data.cs);
}  

void preordertraverse(node *Tree, void (*p)(node *))    //先序遍历
{  
    if(Tree)
    {
        (*p)(Tree);
        preordertraverse(Tree->lchild, (*p)(Tree->lchild));
        preordertraverse(Tree->rchild, (*p)(Tree->rchild));
    }
}

void inordertraverse(node *Tree, void (*p)(node *))    //中序遍历
{  
    if(Tree)
    {
        inordertraverse(Tree->lchild, (*p)(Tree->lchild));
        (*p)(Tree);
        inordertraverse(Tree->rchild, (*p)(Tree->rchild));
    }
}

void postordertraverse(node *Tree, void (*p)(node *))    //后序遍历
{  
    if(Tree)
    {
        postordertraverse(Tree->lchild, (*p)(Tree->lchild));
        postordertraverse(Tree->rchild, (*p)(Tree->rchild));
        (*p)(Tree);
    }
}

错误提示:
Compiling...
ben.c
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(176) : error C2095: 'preordertraverse' : actual parameter has type 'void' : parameter 2
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(176) : error C2198: 'preordertraverse' : too few actual parameters
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(177) : error C2095: 'preordertraverse' : actual parameter has type 'void' : parameter 2
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(177) : error C2198: 'preordertraverse' : too few actual parameters
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(185) : error C2095: 'inordertraverse' : actual parameter has type 'void' : parameter 2
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(185) : error C2198: 'inordertraverse' : too few actual parameters
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(187) : error C2095: 'inordertraverse' : actual parameter has type 'void' : parameter 2
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(187) : error C2198: 'inordertraverse' : too few actual parameters
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(195) : error C2095: 'postordertraverse' : actual parameter has type 'void' : parameter 2
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(195) : error C2198: 'postordertraverse' : too few actual parameters
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(196) : error C2095: 'postordertraverse' : actual parameter has type 'void' : parameter 2
d:\我的文档\procedure\树\benthy_tree\function_tree2.txt(196) : error C2198: 'postordertraverse' : too few actual parameters
Error executing cl.exe.

ben.obj - 12 error(s), 0 warning(s)
Benthy_tree.zip (251.11 KB)
搜索更多相关主题的帖子: 二叉树 void 
2012-06-09 00:21
demonleer
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:10
帖 子:483
专家分:1225
注 册:2012-6-4
收藏
得分:10 
void preordertraverse(node *Tree, void (*p)(node *))    //先序遍历
{  
    if(Tree)
    {
        (*p)(Tree);
        preordertraverse(Tree->lchild, (*p)(Tree->lchild));
        preordertraverse(Tree->rchild, (*p)(Tree->rchild));
    }
}

可以这样写: preordertraverse(Tree->lchild, p); 你的(*p)(Tree->lchild)返回的是void型,preordertraverse的第二个参数是个函数指针。
2012-06-09 02:21
Benthy2
Rank: 1
等 级:新手上路
帖 子:25
专家分:7
注 册:2011-12-16
收藏
得分:0 
thank you!
2012-06-09 09:43
快速回复:遍历二叉树出了问题!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018032 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved