剑指 Offer 27. 二叉树的镜像

请完成一个函数,输入一个二叉树,该函数输出它的镜像。

例如输入:

  1. 4

/ \ 2 7 / \ / \

1 3 6 9

镜像输出:

  1. 4

/ \

7 2

/ \ / \

9 6 3 1

DFS 与 BFS

思路

  1. 要得到根节点为A的二叉树的镜像,需要完成如下三部:
  1. 得到A左子树的镜像left;
  2. 得到A右子树的镜像right;
  3. 将A右子树镜像right链接到A的左子树,相似操作赋予A的左子树镜像。

    算法

    mirrorTree(TreeNode* root)

  4. 终止条件:

    1. 若root为NULL,则直接返回NULL。(NULL的镜像为NULL)
  5. 返回值
    1. 建立左子树镜像,mirrorTree(root.left)
    2. 建立右子树镜像,mirrorTree(root.right)
    3. 交换左右子树
    4. 返回root;

      DFS实现

      1. TreeNode* mirrorTree(TreeNode* root) {
      2. if(!root) return NULL;
      3. auto left=mirrorTree(root->left);
      4. auto right=mirrorTree(root->right);
      5. root->left=right;
      6. root->right=left;
      7. return root;
      8. }

      BFS实现

      1. TreeNode* mirrorTree(TreeNode* root) {
      2. if(!root) return NULL;
      3. queue<TreeNode*> qu;
      4. qu.push(root);
      5. while(!qu.empty()){
      6. auto curNode=qu.front();
      7. qu.pop();
      8. if(curNode->left) qu.push(curNode->left);
      9. if(curNode->right) qu.push(curNode->right);
      10. auto tmp=curNode->left;
      11. curNode->left=curNode->right;
      12. curNode->right=tmp;
      13. }
      14. return root;
      15. }

      复杂度分析

  • 时间复杂度:27- ★二叉树的镜像 - 图1
  • 空间复杂度:27- ★二叉树的镜像 - 图2

扩展1 剑指 Offer 28. 对称的二叉树(判断是否镜像)

请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

  1. 1

/ \ 2 2 / \ / \ 3 4 4 3 但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

  1. 1

/ \ 2 2 \ \ 3 3

❤❤DFS

思路

对称二叉树的定义:对于树种任意两个节点L和R,若对称,一定满足如下两个条件

  • L和R均为NULL时,对称
  • L.left==R.right && L.right=R.left,对称

    实现

    1. bool isSymmetric(TreeNode* root){
    2. if(!root) return true;
    3. return __isSym(root->left,root->right);
    4. }
    5. bool __isSym(TreeNode* L,TreebNode* R){
    6. if(!L && !R) return true;
    7. if(!L || !R || L->val!=R->val) return false;
    8. return __isSym(L->left,R->right) && __isSym(L->right,R->left);
    9. }

    复杂度分析

  • 时间复杂度:27- ★二叉树的镜像 - 图3,左右两边子树每个都需要比较,故比较N/2次。

  • 空间复杂度:27- ★二叉树的镜像 - 图4,最大深度为logN;

❤❤BFS

思路

对于二叉树的每一层,若其元素形成一个回文串,则说明该层元素对称。

实现

  1. bool isSymmetric(TreeNode* root){
  2. queue<TreeNode*> q;
  3. if(!root) return true;
  4. q.push(root);
  5. while(!q.empty()){
  6. string str;
  7. for(int i=0;i<q.size();i++){
  8. auto cur=q.front();
  9. q.pop();
  10. if(cur->left){
  11. q.push(cur->left);
  12. str.push_back(cur->left->val);
  13. }
  14. else{
  15. str.push_bacK(' ');
  16. }
  17. if(node->right){
  18. q.push(node->right);
  19. str.push_back(node->right->val);
  20. }
  21. else str.push_back('');
  22. }
  23. if(!isNotSym(str)) return false;
  24. }
  25. return true;
  26. }
  27. bool isNotSym(const string& str){
  28. string tmp=str;
  29. reverse(tmp.begin(),tmp.end());
  30. return tmp==str;
  31. }

题目标题难度划分

星级 题目难度
简单
☆☆ 中等
☆☆☆ 困难

算法掌握难度程度划分

星级 掌握难度
普通
经典,易掌握
❤❤ 经典,略难掌握
❤❤❤ 困难