| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 717 人关注过本帖
标题:关于三叉树的文本显示问题,用递归实现。。。
只看楼主 加入收藏
haustfanqh
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2013-5-22
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:2 
关于三叉树的文本显示问题,用递归实现。。。
关于三叉树的文本显示问题,用递归实现。。。
最近要写一个项目,要用到三叉树。为了能方便的debug代码,直接显示(给自己看)三叉树的形状。就在网上搜了一下,只找到了二叉树的文本显示。函数如下:

typedef struct Node{
    char data;
    struct Node * Lchild;
    struct Node * Rchild;
}BiTNode,*BiTree;//二叉树节点,二叉链表

执行函数时,为nlayer赋值为1。
void PrintTree(BiTree bt, int nlayer){
    if(bt==NULL)   
        return;
    PrintTree(bt->Rchild,nlayer+1);
    for(int i=0;i<nlayer;i++)   
        printf(" ");   
    printf("%c\n",bt->data);
    PrintTree(bt->Lchild,nlayer+1);
}

这个函数显示的结果还是比较满意的,本想把这个程序改一下,用来显示三叉树的,发现很困难,改了两三天都没有成功。哪位大侠指点一下。。?或者指点一下在哪里可以找到相关参考答案或者代码。

typedef struct ternary_tree_node
{
    char key;   
    int value;
    struct ternary_tree_node * left;
    struct ternary_tree_node * mid;
    struct ternary_tree_node * right;
}TERNARY_NODE, * TERNARY_TREE;
搜索更多相关主题的帖子: 三叉 return 二叉树 
2013-05-27 23:01
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:10 
差不多的,
多少叉都可以一样,先根输出,之后对于每个节点递归输出就行了

伪代码
void PrintTree(ternary_tree_node *bt, int nlayer){
     if(bt==NULL)   
        return;
// 按照你的要求格式输出 就行了   
    printf(bt->key);
    printf(bt->value);

    PrintTree(bt->left);
    PrintTree(bt->mid);
    PrintTree(bt->right);
 }
 

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-05-28 17:36
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:10 
记得看到过 beyond版版 写的三叉树,翻他以前的的帖子


[fly]存在即是合理[/fly]
2013-05-30 20:29
快速回复:关于三叉树的文本显示问题,用递归实现。。。
数据加载中...
 
   



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

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