1、编写递归算法,将二叉树中所有结点的左右子树相互交换。(用C编程)

要快啊,我是上机作业,各位高手,运行出来我加分!不要算法,要C++程序,能运行的... 要快啊,我是上机作业,各位高手,运行出来我加分!
不要算法,要C++程序,能运行的
展开
 我来答
尹之牧
2010-04-29 · TA获得超过134个赞
知道答主
回答量:95
采纳率:0%
帮助的人:37.3万
展开全部
#include<stdio.h>
#include<malloc.h>
typedef struct binode{
int data;
struct binode *lchild,*rchild;
}binode,*bitree;
typedef struct{
bitree elem[100];
int top;
}stack;
bitree creat_bt(){ //按扩展前序建二叉树
bitree t;int x;
scanf("%d",&x);
if (x==0) t=NULL;
else { t=(bitree)malloc(sizeof(binode));
t->data=x;
t->lchild=creat_bt();
t->rchild=creat_bt();
}
return t;
}
void exchange(bitree t) //左、右子树交换
{bitree p;
if(t!=NULL)
{ p=t->lchild;t->lchild=t->rchild;
t->rchild=p;
exchange(t->lchild);
exchange(t->rchild);
}
}
void inorder(bitree bt) //递归的中序遍历
{ if (bt){
inorder(bt->lchild);
printf("% d",bt->data);
inorder(bt->rchild);
}
}
main()
{bitree root;
printf("\n");
printf("建二叉树,输入元素:");
root=creat_bt(); /*create tree of useing preorder*/
printf("交换前的中序序列是:");
inorder(root);
exchange(root);
printf("\n交换后的中序序列是:");
inorder(root);
printf("\n");
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zx198799
2010-04-29 · TA获得超过1225个赞
知道小有建树答主
回答量:509
采纳率:100%
帮助的人:278万
展开全部
void biTreeChange(biTree tr)
{
if (tr == NULL) return;
pNode pn = tr->left;
tr->left = tr->right;
tr->right = pn;
biTreeChange(tr->left);
biTreeChange(tr->right);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式