交换二叉树的所有节点的左右子树算法(C语言)

2025-01-05 06:12:35
推荐回答(4个)
回答1:

二叉树最好使用递归的算法,假设二叉树节点定义如下:
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);
changeleaf(anode->right);
}
};

回答2:

递归的交换就可以了。
struct Node
{
int value;
Node * left;
Node * right;
};

void exchange(Node * node)
{
if(node == NULL) return;
Node * temp = node->left;
node->left = node->right;
node->right = temp;

exchange(node->left);
exchange(node->right);
}

回答3:

#include
#include
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");
}

回答4:

void Bitree_Revolute(BiTree b){
if(b){ //结点非空
Bitree_Revolute(b->lchild); //递归左子树

Bitree_Revolute(b->rchild);//递归右子树

Bitree temp = b->lchild; //结点类型设为Bitree,交换左右节点

b->lchild = b->rchild;

b->rchild = temp;

}
}