| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 288 人关注过本帖
标题:先序非递归输出的问题【求助】
只看楼主 加入收藏
q1826050194
Rank: 2
等 级:论坛游民
帖 子:67
专家分:19
注 册:2011-3-7
结帖率:77.78%
收藏
已结贴  问题点数:20 回复次数:2 
先序非递归输出的问题【求助】
#include<stdio.h>
#include<stdlib.h>

typedef struct nodf     //树的结点结构体
{
    int data;
    struct nodf *lchild,*rchild;
}bitree;
bitree *Q[20];//定义一个指向bitree的指针数组

typedef struct node
{
    bitree *s;
    struct node *next;
}linkstack;
linkstack *top=NULL;//空栈


linkstack *push(linkstack *top,bitree *x)//进栈
{
    linkstack *p;
    p=(linkstack*)malloc(sizeof(linkstack));
    p->s=x;
    p->next=top;
    top=p;
    return top;
}

linkstack *pop(linkstack *top)//出栈
{
    linkstack *p;
    p=top;
    top=top->next;
    free(p);
    return top;
}

int empty(linkstack *s)
{
    if(s->next==NULL)
    return 1;
    else
    return 0;
}

bitree *creatree()
{
    int ch;
    int front=1,rear=0;
    bitree *root,*s;
    root=NULL;
    scanf("%d",&ch);
    while(ch!=-1)
    {
        s=NULL;
        if(ch!=0)
        {
            s=(bitree*)malloc(sizeof(bitree));
            s->data=ch;
            s->lchild=NULL;
            s->rchild=NULL;
        }
        rear++;
        Q[rear]=s;
        if(rear==1)  root=s;
        else
        {
            if(s!=NULL&&Q[front]!=NULL)
            {
                if(rear%2==0)  Q[front]->lchild=s;
                else           Q[front]->rchild=s;
                if(rear%2==1)  front++;
            }
        }
        scanf("%d",&ch);
    }
    return root;
}


void pri(bitree *s,linkstack *top)//先序排列 非递归
{
    linkstack *acc;
    while(s!=NULL||(empty(top)==0))
    {
        while(s!=NULL)
        {
            printf("%d ",s->data);
                top=push(top,s);
                s=s->lchild;
        }
        if(s==NULL)
        {
            acc=pop(top);                //这里的出栈并不能使free里的实参回收,导致不断地循环  可是我想不出应该怎么去修改
            s=acc->s->rchild;
        }
    }
}

int main()
{
    bitree *tree=creatree();
    pri(tree,top);
    return 0;
}
 
搜索更多相关主题的帖子: 结构体 return 
2011-05-30 10:24
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:20 
太长了。。。。

                                         
===========深入<----------------->浅出============
2011-05-30 11:00
q1826050194
Rank: 2
等 级:论坛游民
帖 子:67
专家分:19
注 册:2011-3-7
收藏
得分:0 
回复 2楼 laoyang103
这个答案好像不太好咧···
2011-05-30 15:06
快速回复:先序非递归输出的问题【求助】
数据加载中...
 
   



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

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