二叉树先序遍历的非递归算法(用栈实现)

RT... RT 展开
 我来答
匿名用户
推荐于2017-10-13
展开全部
typedef char DataType;
typedef struct node{
DataType data;
struct node *lchild,*rchild;
}BinTNode;

typedef BinTNode *BinTree;

int count;
void CreateBinTree(BinTree *T);
void PreorderN(BinTree T);

#define StackSize 10 /*假定预分配的栈空间最多为10*/
typedef BinTree SDataType; /*栈的元素类型设为整型*/
#define Error printf
typedef struct{
SDataType data[StackSize];
int top;
}SeqStack;

void InitStack(SeqStack *S) /*初始栈*/
{
S->top=-1;
}

int StackEmpty(SeqStack *S) /*判栈空*/
{
return S->top==-1;
}

int StackFull(SeqStack *S) /*判栈满*/
{
return S->top==StackSize-1;
}

void Push(SeqStack *S, SDataType x) /*进栈*/
{
if(StackFull(S))
Error("栈已满\n"); /*上溢退出*/
else S->data[++S->top]=x; /*栈顶指针加1后将x进栈*/
}

SDataType Pop(SeqStack *S) /*出栈*/
{
if (StackEmpty(S))
Error("Stack underflow"); /*下溢退出*/
else return S->data[S->top--]; /*栈顶指针返回后将栈顶指针减1*/
}

SDataType StackTop(SeqStack *S) /*取栈顶元素*/
{
if (StackEmpty(S))
Error("栈已空\n");
return S->data[S->top];
}

main()
{
BinTree T;
char ch1,ch2;
printf("\n欢迎进入二叉树操作测试程序,请选择:\n");
ch1='y';
while(ch1=='y' || ch1=='Y')
{printf("\nA-------------------------二叉树建立");
printf("\nB-------------------------先序遍历(非递归)");
printf("\nC-------------------------退出\n");
scanf("\n%c",&ch2);
__page_break__
switch(ch2)
{case 'A':
case 'a':printf("按二叉树带空指针的先序次序输入结点:\n");
CreateBinTree(&T);
printf("二叉树建立成功\n");break;
case 'B':
case 'b':printf("遍历的结果为:\n");
PreorderN(T);break;
case 'C':
case 'c':ch1='n';break;
default:ch1='n';
}
}
}

void CreateBinTree(BinTree *T)
{
char ch;
scanf("\n%c",&ch);
if (ch=='0') *T=NULL;
else
{
*T=(BinTNode*)malloc(sizeof(BinTNode));
(*T)->data=ch;
CreateBinTree(&(*T)->lchild);
CreateBinTree(&(*T)->rchild);
}
}

void PreorderN(BinTree T)
{/*先序遍历二叉树T的非递归算法*/
SeqStack *S;
BinTree p;
InitStack(S);Push(S,T); /*根指针进栈*/
while(!StackEmpty(S))
{while(p=StackTop(S))
{ printf("%3c",p->data); /*访问入栈结点的数据域*/
Push(S,p->lchild); /*向左走到尽头*/
}
p=Pop(S); /*空指针退栈*/
if (!StackEmpty(S)) /*输出结点,向右一步*/
{p=Pop(S);
/* printf("%3c",p->data); */
Push(S,p->rchild);
}
}
}/*PreorderN */
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式