小弟今年考研,这是计算机专业的一道真题,算法设计是小弟的弱项,请各位大侠帮帮忙。

编写一个算法,利用叶子结点中的空指针域,将以二叉链表存储的二叉树中的所有叶子结点链接为一个带有头结点的双链表,算法返回头结点的地址。
(1)给出算法的基本设计思想;
(2)根据设计思想,用C或C++或JAVA语言描述算法,关键之处给出注释。

#include<stdio.h>
typedef struct node
{
char c;
int count;
struct node *left,*right;
}bnode;bnode *k,*m; // 分别记录叶子链表的第一及当前结点的前驱
bnode *creatree(bnode *ptr,char ch) // 建二叉树
{
int result;bnode *p,*r; // p 指向当前结点的最近的父结点
p=NULL;
r=ptr;
while(r)
{ // 检查是否存在相同结点
result=(int)(r->c)-(int)(ch);
if(!result)
{
r->count+=1;
return r;
}
else
{
p=r;
r=result<0?r->right:r->left;
}}
r=(struct node *)malloc(sizeof(bnode));// 建新结点
r->left=r->right=NULL;
r->c=(char)malloc(sizeof(char));
r->c=ch;
r->count=1;
if(!ptr)
return r;
else if(result>0)
p->left=r;
else p->right=r;
return r;}
leaflink(bnode *root)
{if(!root)return;
if(root->left==NULL&&root->right==NULL)
{if(k==NULL)k=m=root; // 保存找到的第一个叶子结点(k指针)
else {m->right=root;m=m->right;
}}if(root->left)
leaflink(root->left);
if(root->right)
leaflink(root->right);
return;
}
main()
{
char *s;
bnode *root=NULL;
printf("Input a string:");
scanf("%s",s);
do{if(!root)root=creatree(root,*s);
else creatree(root,*s);
s+=1;}
while(*s);
leaflink(root); // 将叶结点链成链表
while(k)
{
printf("%c",k->c);k=k->right;
} // 输出该链表
}
另外给个参考链接http://www.doc88.com/p-403985337591.html
温馨提示:内容为网友见解,仅供参考
无其他回答
相似回答