思路:
二叉树有关的题大多都会用到递归,而且对二叉树的处理无非通过前序中序后序三种方式,就看你需要用哪一种遍历。个人感觉二叉树做题就是递归+操作,选一个合适的递归,然后在恰当的位置插入对节点进行操作的代码。而递归就是通过调用函数传左右节点实现的,递归的过程不需要深究,只需要知道这么一通操作之后,我已经完成了我遍历的目的,这就够了。
代码也可分为三部分,首先是节点是否为空的判断,如果不是空节点,由于是采用先序遍历,那么此刻该执行“操作”步骤,也就是需要我们自己补完的交换节点的代码;
之后就是二叉树的递归遍历过程,传节点就可以了~
class Solution {
public:
TreeNode* invertTree(TreeNode* root) {
if(!root)
return NULL;
TreeNode* temp=root->left;
root->left=root->right;
root->right=temp;
invertTree(root->left);
invertTree(root->right);
return root;
}
};



