标题:被这里的指针搞乱了,大家帮忙看看
取消只看楼主
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
结帖率:97.44%
已结贴  问题点数:20 回复次数:1 
被这里的指针搞乱了,大家帮忙看看
#include<stdio.h>
#include<stdlib.h>

#define MAXNUM 100
struct BiTreeNode;        /*二叉树中的结点*/
typedef struct BiTreeNode *PBiTreeNode;/*结点的指针类型*/

struct BiTreeNode
   
{
    char info;
    PBiTreeNode llink;
    PBiTreeNode rlink;
};

//typedef struct BiTree *PBiTree;
typedef struct BiTreeNode *BiTree;

struct SeqStack
 {
        BiTree s[MAXNUM];
        int t;
 };
 
 typedef struct SeqStack *PSeqStack;
 
  PSeqStack createEmptyStack_seq(void)
 {
     PSeqStack pastack;
     pastack = (PSeqStack)malloc(sizeof(struct SeqStack));
     if(pastack == NULL)
         printf("Out of space!!\n");
     else
          pastack->t = -1;
     return (pastack);
  }
  
  int isEmptyStack_seq(PSeqStack pastack)
 {
     return(pastack->t == -1);
 }
  
 void push_seq(PSeqStack pastack, PBiTreeNode p)
  {
    if(pastack->t >= MAXNUM -1)
    {
         printf("Overflow!\n");
     }
     else
      {
         pastack->t = pastack->t + 1;
         pastack->s[pastack->t] = p->s[pastack->t];
      }
}

 void pop_seq(PSeqStack pastack)
 {
      if(pastack->t == -1)
         printf("Underflow! \n");
    else
         pastack->t = pastack->t - 1;
  }
 
 int top_seq(PSeqStack pastack)
 {
    return(pastack->s[pastack->t]);
  }
PBiTree createTree(PBiTree bt)
{
    char ch;
    //printf("please input data:\n");
    scanf("%c",&ch);
   
    if(ch=='#')
    {
        bt=NULL;
    }
    else
    {
        bt=(BiTree)malloc(sizeof (BiTreeNode));
        if(!t)
            exit(0);
        bt->data=ch;
        bt->lchild=CreateTree(bt->lchild);
        bt->rchild=CreateTree(bt->rchild);
    }
    return t;
}
void PreOder(PBiTree bt)
{
    PSeqStack pastack;
    BiTreeNode *c;
    if(t==NULL)
        return;
    pastack=createEmptyStack_seq();
    push_seq( pastack, bt);
    while(!isEmptyStack_seq(pastack))
    {
        c=top_seq(pastack);
        pop_seq(pastack);
        if(c!=NULL)
        {
            printf("%c".c->data);
            push_seq( pastack, llink);
            push_seq( pastack, rlink);

        }
    }

}
int main()
{
    PBiTree bt=NULL;
    bt=createTree(bt);
    printf("Pre Order:\n");
    PreOder(bt);
    return 0;
}
搜索更多相关主题的帖子: 二叉树 
2011-04-06 16:34
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
得分:0 
谢谢版主指点,
2011-04-06 20:48



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




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

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