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

要快啊,我是上机作业,各位高手,运行出来我加分!
不要算法,要C++程序,能运行的

第1个回答  2010-04-29
#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");
}本回答被提问者采纳
第2个回答  2010-04-29
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);
}

交换二叉树的所有节点的左右子树算法(C语言)
二叉树最好使用递归的算法,假设二叉树节点定义如下:typedef struct node{ int a;node* left;node* right;};可以定义交换左右子树的函数如下:void changeleaf(node* anode){ if(anode!=0){ node* tnode=anode->left;anode->left=anode->right;anode->right=tnode;changeleaf(anode->left);cha...

...试写出算法(C函数):将所有结点的左右子树互换。
(5)LSIBLING(BT,x) 和 RSIBING(BT,x) 求兄弟函数。分别求二叉树 BT中结点 x的左兄弟和右兄弟结点。若结点 x是根结点或不在 BT中或是其双亲的左 \/右子树根 ,则函树值 为 “空 ”。(6)CRT_BT(x,LBT,RBT) 建树操作。生成一棵以结点 x为根,二叉树 LBT和 RBT分别为左, 右子树的二...

若二叉树采用二叉链表存储结构,要交换其所有分支结点左、右子树的位置...
【答案】:C 本题用后序遍历肯定没问题,不过用层次遍历也可以实现,所以选D也不能算错,相比之下,后序遍历实现的程序更容易理解,作为单项选择题,首选的应该是C。

编写递归算法,计算二叉树中叶子结点的数目。(C++)急!!!
using namespace std;typedef struct TNode\/\/二叉树结构 { char nodeValue;\/\/结点的值 TNode* left;\/\/左子树 TNode* right;\/\/右子树 }*BiTree;void CreateBiTree(BiTree &T)\/\/中序遍历方式创建二叉树 ,输入#代表该结点为空 { char nodeValue;cin>> nodeValue;if(nodeValue!='#')\/\/结点非...

若二叉树采用二叉链表存储结构,要交换其所有分支结点左、右子树的位置...
答案:C。用二叉链表存储结构也就是左孩子右兄弟的存储结构。后序遍历比较合理。正常的逻辑应该就是:做好当前结点子树内部的交换,然后交换当前结点的左右子树。刚好符合后序遍历的算法逻辑。1、交换好左子树 2、交换好右子树 3、交换左子树与右子树 其他算法如先序和按层次其逻辑都差不多,即访问当前...

写一个算法,交换一棵二叉树T的左右子树,要求使左子树根结点的关键字k小...
\/\/递归算法(更像伪代码)void swap(BT root){ if(root){ if(root.l&&root.r&&(*root.l).key>(*root.r).key){ BT p=(*root).l;(*root).l=(*root).r;(*root).r=p;} swap((*root).l);swap((*root).r);} }

编写递归算法,求二叉树的结点个数和叶子数
return(0);} 法二:int LeafCount_BiTree(Bitree T)\/\/求二叉树中叶子结点的数目 { if(!T) return 0; \/\/空树没有叶子 else if(!T->lchild&&!T->rchild) return 1; \/\/叶子结点 else return Leaf_Count(T->lchild)+Leaf_Count(T->rchild);\/\/左子树的叶子数加 上右子树的叶子数 }\/...

数据结构二叉树的基本操作~~~
用递归的方法实现以下算法:1.以二叉链表表示二叉树,建立一棵二叉树;2.输出二叉树的前序遍历结果;3.输出二叉树的中序遍历结果;4.输出二叉树的后序遍历结果;5.统计二叉树的叶结点个数;6.统计二叉树的结点个数;7.计算二叉树的深度。8.交换二叉树每个结点的左孩子和右孩子;include <...

请大神用C语言帮编一个关于家谱的程序!要求:
\/\/生成根结点 CreateBiTree(T->lchild);\/\/构造左子树 CreateBiTree(T->rchild);\/\/构造右子树 } return OK;}\/\/CreateBiTree void PreOrder(BiTree T)\/\/采用二叉链表存储结构,先序遍历二叉树T,对每个结点的访问就是输出它的值 { if(T){ printf("%c",T->data);...

编写程序,用先序递归遍历法建立二叉树的二叉链表存储结构,输出其先序...
BiTNode *bulid() \/*建树*\/ { BiTNode *q;BiTNode *s[20];int i,j;char x;printf("请按顺序输入二叉树的结点以输入0和*号结束\\n");printf("请输入要输入的为第几个结点i=\\n");scanf("%d",&i);printf("请输入你要输入该结点的数为x=");getchar();scanf("%c",&x);while(i!=...

相似回答