标题:关于二叉树非递归遍历是指针调用的问题
取消只看楼主
qq8801103
Rank: 5Rank: 5
来 自:苏州中科大软件学院
等 级:职业侠客
威 望:1
帖 子:422
专家分:340
注 册:2009-10-8
结帖率:73.96%
已结贴  问题点数:10 回复次数:1 
关于二叉树非递归遍历是指针调用的问题
#define STACK_INIT_SIZE 100
#define STACKINCREMENT  10
#include <stdio.h>
#include <stdlib.h>
typedef char TElemType;
typedef struct BiTNode
{
    TElemType data;
    struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;
typedef struct
{
    BiTree *base;
    BiTree *top;
    int stacksize;
}SqStack;
void initialStack(SqStack *s)
{
    s->base=(BiTree *)malloc(STACK_INIT_SIZE*sizeof(BiTree));
    if(!s->base) exit(0);
    s->top=s->base;
    s->stacksize=STACK_INIT_SIZE;
}
void Push(SqStack *s,BiTNode *e)
{
    if(s->top-s->base>=s->stacksize)
    {
        s->base=(BiTree *)realloc(s->base,(STACK_INIT_SIZE+STACKINCREMENT)*sizeof(BiTree));
        if(!s->base) exit(0);
        s->top=s->base+s->stacksize;
        s->stacksize+=STACKINCREMENT;
    }
    *(s->top)++=e;
}
void Pop(SqStack *s,BiTree *e)
{
    if(s->top==s->base) exit(0);
    *e=*--(s->top);
}
int GetTop(SqStack *s,BiTree *e)
{
    if(s->top==s->base) return(0);
    *e=*(s->top-1);
    return(1);
}
int StackEmpty(SqStack *s)
{
    if(s->base==s->top)
        return(1);
    else
        return(0);
}

void CreatBiTree(BiTree *T)
{
    TElemType ch;
    scanf("%c",&ch);  fflush(stdin);
    if(ch=='#')
    *T=NULL;
    else
    {
    *T=(BiTNode *)malloc(sizeof(BiTNode));
    if(!*T)
            exit(0);
    (*T)->data=ch;
    CreatBiTree(&(*T)->lchild);
    CreatBiTree(&(*T)->rchild);
    }

}

void Visit(char p)
{
    printf("%c",p);
}
void InOrderTraverse(BiTree T)
{
    SqStack S;
    BiTree p;
    initialStack(&S);
    p=T;
    while(p||!StackEmpty(&S))
    {
        if(p)
        {
            Push(&S,p);
            p=p->lchild;
        }
        else
        {
            Pop(&S,&p);
        Visit(p->data);
            p=p->rchild;
        }
    }
}
void main()
{
    BiTree *t;
    printf("jianlishu:\n");
    printf("shurijieidian:");
    CreatBiTree(t);
    printf("zhongshubianlidejieguowei:");
    InOrderTraverse(*t);
    printf("\n");
}

不理解在构建二叉树中和遍历的时候,请解释一下 详细一点
搜索更多相关主题的帖子: 二叉树 遍历 递归 指针 
2010-05-21 20:00
qq8801103
Rank: 5Rank: 5
来 自:苏州中科大软件学院
等 级:职业侠客
威 望:1
帖 子:422
专家分:340
注 册:2009-10-8
得分:0 
谢谢了  问一下2楼的那个  你的编程工具是什么  可以传上来吗

Discuz!  
好好学习  天天向上
2010-05-24 14:00



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




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

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