标题:[求助]有程序,不知道怎么输入~
只看楼主
ice0violet
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-9-27
 问题点数:0 回复次数:6 
[求助]有程序,不知道怎么输入~
题目:请设计一个算法,把二叉树的叶子结点按从左到右的顺序连成一个单链表。二叉树用二叉链存储,链接时用叶子结点的rchild 域存放指针。
求高手帮帮忙,下面有我的程序代码,可是调试的时候不知道怎么输入二叉树测试~

[此贴子已经被作者于2006-12-14 15:49:33编辑过]

搜索更多相关主题的帖子: 输入 
2006-12-11 18:09
longerhe
Rank: 1
等 级:新手上路
帖 子:120
专家分:0
注 册:2006-10-10
得分:0 
先遍历二叉树,如果是叶子就修改它的rchild域,使它指向前面那个叶子..
2006-12-11 20:09
xxygdufs
Rank: 1
等 级:新手上路
帖 子:45
专家分:0
注 册:2006-5-11
得分:0 
while(p)
{
p=p->next;
}
然后把找到的结点地址一个一个存入单链表

2006-12-12 12:43
ice0violet
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-9-27
得分:0 

Thanks!

2006-12-13 21:22
ice0violet
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-9-27
得分:0 

#include <stdio.h>
#include <alloc.h>
#include <string.h>
#include <ctype.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;} // 输出该链表
}

2006-12-13 22:41
ice0violet
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2006-9-27
得分:0 
这个程序要怎么输入二叉树啊?
我弄来弄去都弄不明白~
嗯,还有,要怎么样才能加一部分打印输入的二叉树的算法啊?
2006-12-13 22:42
e4lich
Rank: 2
等 级:新手上路
威 望:4
帖 子:182
专家分:0
注 册:2006-10-26
得分:0 
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;
}
你的这个函数就是建立二叉树的啦!输出二叉树的话,可以用先中后等三种遍历方法,还有递归与非递归让你选!

我只想变强!     
2006-12-16 11:38



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-108852-1-1.html




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

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