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

编写一个算法,利用叶子结点中的空指针域,将以二叉链表存储的二叉树中的所有叶子结点链接为一个带有头结点的双链表,算法返回头结点的地址。
(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
温馨提示:内容为网友见解,仅供参考
无其他回答

这是一道计算机考研的真题,希望各位大侠帮帮忙,小弟将不胜感激!_百度...
直接编码 一位代表一个微操作命令 那就是 3+3+5+8=19 字段直接编码 互斥的放一个段,还要留出一种情况不发 各段需要位数 2+2+3+4=11 同理水平型字段直接编码 2+2+3+4+3=14 26-14=12 故存储器的地址位数为12位 指令长为26位 ,所以2^12*26 ...

这是我运算时遇到的问题,各位大侠帮帮忙
把等号右边的分母化为k的绝对值分之根号下1+k的平方 再往下做就解出来了,不用平方,那样计算量太大

模具设计跟产品设计哪个更容易学?各位大侠请帮忙一下
产品设计简单一点,一般的产品设计主要考虑外观,功能和组配,需要的知识点表少,一般2年时间可以成熟,独立进行设计制作,当然如果高深的产品设计就很难,比如需要进行材料选择和应力计算这些真的需要工程院的人才能做。模具设计涉及到的知识点比较多,加工要懂,材料要懂,标准件选用等等,而且成熟一点的模具师傅估计时间要3~...

怎么做,第四题请各位大侠们帮帮小弟
5.5*2000000\/5000000=2.2cm

这是一到六年级的数学题,请各位大侠帮忙
解:不用方程法。解题分析如下:假若每分钟前来检票处排队检票的人数一定,每个检票口的检票速度也一定。所以,开两个检票口时8分钟检票数量相当于开一个检票口时的16分钟,所以,相差(20-16)分钟为(20-8)分钟时间内新增的排队人数。也即每分钟增加的排队人数需要一个检票口(20-16)\/(20-8)...

今天去芜湖广济寺求签,给了我 这个 签,小弟愚鲁,请各位大侠帮解签...
在下不才,看字面意思,应该是个下下签吧, 你问的事情对你以后发展不吉利,不如做好现在的工作还能快乐平安,如果你不信本神的话,等你失去的时候(钱财或者感情)一定会痛不欲生

麻烦各位大侠帮小弟一个忙,最淡的颜色是什么颜色,三个字,是有某种东西...
鹅黄色 桃粉色 橘黄色 柠檬黄

请各位电脑高手大侠帮忙一下一个疑难的问题!小弟感激不尽
嗯,我以前也遇到过这种情况。只要将原来的摄像头驱动卸载,再重新安装就可以了。用GHOST或Windows XP自带的系统还原功能可以快速恢复到安装前的状态。当然,你也可以重装系统。如果上述方法不行,建议检查一下硬件本身的问题。参考资料:无

想了解关于考研的亲身经历,诚望各位大侠出手相助!
1. 专业课复习进度大约和政治一致便可。跨专业考的同学复习进度跟数学一样便可。不需要太早复习,因为数学跟英语的复习任务是很重的。2. 真题是绝对应该重视的!!!(要知道专业课出题老师也是很懒的,懒是人的天性啊,哈哈!每年的试卷十有八九会包含有几道前几年的原题,最起码考点是几乎每年都...

各位大侠,小弟问一道题。各位一定要写下计算的过程! 急!!!题目如下...
一日一夜 是24小时 即 24*60*60=86400 秒 一须臾 = 86400\/30 = 2880 秒 一罗预 = 2880\/20 = 144 秒 一弹指 = 144\/20 = 7.2 秒 一瞬 = 7.2\/20 = 0.36 秒 一念 = 一刹那 = 0.36\/20 =0.018秒

相似回答