关于三叉树的文本显示问题,用递归实现。。。
最近要写一个项目,要用到三叉树。为了能方便的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; //Notice: not a string!!!
int value;
struct ternary_tree_node * left;
struct ternary_tree_node * mid;
struct ternary_tree_node * right;
}TERNARY_NODE, * TERNARY_TREE;