标题:想测试树的前 中序遍历,可是运行不出结果!请大家帮忙看看
只看楼主
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
结帖率:97.44%
已结贴  问题点数:20 回复次数:3 
想测试树的前 中序遍历,可是运行不出结果!请大家帮忙看看
#include<stdio.h>
#include<stdlib.h>

#define MAX 100
typedef struct BiNode//二叉树结点结构体
{
    char data;
    struct BiNode *lchild;
    struct BiNode *rchild;//左右孩子指针
}BiNode;

typedef BiNode *BiTree;//二叉树结点指针类型

typedef struct //二叉树结点栈
{
    BiTree stack[MAX+1];
    int flag[100];
    int top;
}SqStack;

typedef struct QNode//二叉树结点队列
{
    BiTree data;
    struct QNode *next;
   
}QNode;
typedef QNode *QueuePtr;

typedef struct
{
    QueuePtr *front;
    QueuePtr    *rear;
}LinkQueue;

void InitStack(SqStack *S)//初始化栈
{
    int i;
    S->top=0;
    for(i=0;i<MAX;i++)
    {
        S->stack[S->top]=NULL;
    }
}
void Push(SqStack *S,BiTree e)
{
    BiTree p;
    p=(BiTree)malloc(sizeof(BiNode));
    if(S->top==MAX-1)
    {
        printf("概栈已满!\n");
    }
    else
    {
        S->top++;
        S->stack[S->top]=p;
    }
}
void Pop(SqStack *S,BiTree e)
{
        BiTree p;
        if(S->top==0)
        {
            printf("该栈为空栈,无法弹出栈顶元素!\n");
        }
        else
        {
            p=S->stack[S->top];
            S->stack[S->top]=NULL;
            S->top--;
        }
}
int Top(SqStack *S)
{
    BiNode *p;
    if(S->stack[S->top]==NULL)
        printf("Stack is Empty!\n");
    else
         p=S->stack[S->top];
    return 0;
}
int StackEmpty(SqStack *S)
{
    if(S->top==0)
        return 1;
    else
        return 0;
}
BiTree CreateTree(BiTree t)
{
    char ch;
    //printf("please input data:\n");
    scanf("%c",&ch);
    if(ch=='#')
    {
        t=NULL;
    }
    else
    {
        t=(BiNode*)malloc(sizeof(BiNode));
        if(!t)
            exit(0);
        t->data=ch;
        t->lchild=CreateTree(t->lchild);
        t->rchild=CreateTree(t->rchild);
    }
    return t;
}
void Visit(BiTree t)
{
    printf("%c",t->data);
}
void PreOrder(BiTree t)
{
    SqStack S;
    BiNode *pre=t;
    if(t==NULL)
        exit(0);
    InitStack(&S);
    //printf("输出前序遍历序列:");
    while(!StackEmpty(&S))
    {
        //pre=Top(&S);
        //Pop(&s,c);
        if(pre!=NULL)
        {
             Visit(t);
            //S->stack[S->top++]=pre;
            Push(&S,pre);
            pre=pre->lchild;
        }
        else
        {
            Pop(&S,pre);
            pre=pre->rchild;
        }
    }
    printf("\n");

}
void InOrder(BiTree t)
{
    SqStack S;
    BiNode *pre=t;
    if(t==NULL)
        exit(0);
    InitStack(&S);
    //printf("输出中序遍历序列:");
    while(!StackEmpty(&S))
    {
        //c=top(&S);
        //Pop(&s,pre);
        if(pre!=NULL)
        {
            
            //S->stack[S->top++]=pre;
            Push(&S,pre);
            pre=pre->lchild;
        }
        else
        {
            Pop(&S,pre);
            Visit(t);
            pre=pre->rchild;
        }
    }
    printf("\n");
}
int main()
{
    BiTree bt=NULL;
    bt=CreateTree(bt);

    printf("Pre Order:\n");
    PreOrder(bt);
    printf("In Order:\n");
    InOrder(bt);
    return 0;
}
搜索更多相关主题的帖子: 二叉树 结构体 
2011-03-31 22:03
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:20 
自己再 改下  堆栈函数就有问题

换成递归的成功后 再改成非递归的
2011-04-01 10:27
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
得分:0 
自己改了一点,还是运行不出来,
2011-04-01 13:05
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
得分:0 
递归的搞定了,

[ 本帖最后由 世界模型 于 2011-4-1 18:36 编辑 ]
2011-04-01 18:29



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




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

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