struct TreeNode
{
TreeNode(int _val):val(_val){}
TreeNode *left;
TreeNode *right;
private:
int val;
}
void reverse(TreeNode *root)
{
if(!root)
return;
queue<TreeNode *> q;
q.push(root);
TreeNode *p,*tmp;
while(!q.empty()){
p=q.front();
q.pop();
tmp=p->left;
p->left=p->right;
p->right=tmp;
if(p->left)
q.push(p->left);
if(p->right)
q.push(p->right);
}
}

本文介绍了一种使用队列实现的二叉树节点左右子节点的反转算法,通过遍历二叉树并交换每个节点的左右子节点指针,实现了整棵树的结构翻转。
1350

被折叠的 条评论
为什么被折叠?



