免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2215 | 回复: 7
打印 上一主题 下一主题

有关二叉树的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-23 23:10 |只看该作者 |倒序浏览
请设计一个算法,把二叉树的叶子结点按从左到右的顺序连成一个单链表。二叉树用二叉链存储,链接时用叶子结点的rchild 域存放指针。



#include<stdio.h>
#include<string.h>
#include<conio.h>
#include<stdlib.h>
typedef struct node
{
        char data;
        struct node *lchild,*rchild;//左右孩子的指针
}bitnode,*bitree;
typedef struct lnode
{
        char data;
        struct lnode *next;
}linklist;
typedef struct quenode
{
        bitnode *a;
        struct quenode *next;
}qnode;

typedef struct qu//队列
{
        qnode *front;
        qnode *rear;
}queue;
void initqueue(queue *q)//队列初始化
{
        q->front=q->rear=(qnode*)malloc(sizeof(qnode));
        q->front->next=NULL;
}
void ing(queue *q,bitnode *e)
{
        qnode *s;
        s=(qnode*)malloc(sizeof(qnode));
        s->a=e;
        q->rear->next=s;
        s->next=NULL;
        q->rear=s;
}
void deq(queue *q,bitnode *e)
{
        qnode *p;
        p=(qnode*)malloc(sizeof(qnode));
        e=q->front->next->a;
        p=q->front->next;
        q->front->next=q->front->next->next;
        free(p);
}
static createtree(bitree t)//按先序遍历建立的二叉树
{
        char ch;
        scanf("%c",&ch);
        if(ch=='*') t=NULL;
        else
        {
                if(!(t=(bitnode*)malloc(sizeof(bitnode)))) exit(0);
                t->data=ch;
                createtree(t->lchild);
                createtree(t->rchild);
        }
        return 1;
}
linklist *head;
void transformlink(bitree t,queue *q)//将树通过队列,从上到下储存到链表中
{
        ing(q,t);
        linklist *p2,*p3;
        head=(linklist*)malloc(sizeof(linklist));
        p2=head;
        while(1)
        {
                bitnode e;
                if(q->front==q->rear) break;
                if(q->front->next->a->lchild!=NULL)
                {
                        ing(q,q->front->next->a->lchild);
                }
                if(q->front->next->a->rchild!=NULL)
                {
                        ing(q,q->front->next->a->rchild);
                }
                deq(q,&e);
                p3=(linklist*)malloc(sizeof(linklist));
                p3->data=e.data;
                p3->next=NULL;
                p2->next=p3;
                p2=p3;
        }
}
void input()
{
        linklist *p;
        p=head->next;
        while(p!=NULL)
        {
                printf("%c",p->data);
                p=p->next;
        }
}
int main()
{
        queue q;
        bitnode t;
        initqueue(&q);
        createtree(&t);
        transformlink(&t,&q);
        input();
        return 0;
}


看一下这个程序哪边有错,谢谢了!

论坛徽章:
0
2 [报告]
发表于 2010-06-24 00:13 |只看该作者
首先,你这个能编译码?

论坛徽章:
0
3 [报告]
发表于 2010-06-24 12:30 |只看该作者
回复 2# donglongchao


    可以的,编译是通过的

论坛徽章:
0
4 [报告]
发表于 2010-06-24 13:36 |只看该作者
你是不是在windows下用的turbo c之类的古老编译器啊?

论坛徽章:
0
5 [报告]
发表于 2010-06-30 17:52 |只看该作者
回复 4# donglongchao


    不是,我是用VC++6.0的,不过那个程序已经解决了,谢谢了哦。

论坛徽章:
0
6 [报告]
发表于 2010-06-30 18:40 |只看该作者
本帖最后由 没本 于 2010-06-30 18:54 编辑

#include<conio.h> 是亮点。80年代末我在DOS系统下还用过。
tc2.0

conio.h

论坛徽章:
0
7 [报告]
发表于 2010-06-30 19:04 |只看该作者
本帖最后由 donglongchao 于 2010-06-30 19:09 编辑

回复 6# 没本
所以我才怀疑他可能使用了turbo c之类的编译器。。。

论坛徽章:
0
8 [报告]
发表于 2010-06-30 19:13 |只看该作者
回复 7# donglongchao


    所以C语言强大。16位的到64位的,不同架构的,程序都不用做太大的改动。汇编在这方面就差远了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP