zoukankan      html  css  js  c++  java
  • [leetCode]101对称二叉树

    在这里插入图片描述

    解法1

    使用递归求解,把该问题转化为:两棵树在什么情况下是镜像的?

    • 两颗树的根节点相同
    • 每个树的右子树和令一棵树的左子树相同
      这样可以通过两个指针的同时移动来遍历这棵树,一开始指针p、q同时指向根节点。指针p左移时,q右移动判断值是否相等; 指针p右移时,q左移动判断值是否相等。

    C++

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        bool check(TreeNode *p, TreeNode *q){
            if(!p && !q) return true;//两颗树都为空
            if(!p || !q) return false;//一棵树为空,一棵树不为空
            //p指针往左移动时,q指针往右移动;p指针往右移动时,q指针往左移动;
            return p->val == q->val && check(p->left,q->right) && check(p->right,q->left);
        }
        bool isSymmetric(TreeNode* root) {
            return check(root, root);
        }
    };
    

    java

    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode(int x) { val = x; }
     * }
     */
    class Solution {
        public boolean check(TreeNode p, TreeNode q){
            if(p == null && q == null)return true;
            if(p == null || q == null)return false;
            return p.val == q.val && check(p.left,q.right) && check(p.right,q.left);
        }
        public boolean isSymmetric(TreeNode root) {
            return(check(root,root));
        }
    }
    

    解法二

    迭代解法。首先创建一个队列,先将根节点添加两次,判断是否对称,再将两棵树的子节点按左右相反顺序插入队列,如果是对称的则每次取出的两个节点的值是相等的。当队列为空或者不满足对称时停止。

    C++

    class Solution {
    public:
        bool check(TreeNode *u, TreeNode *v) {
            queue <TreeNode*> q;
            q.push(u); q.push(v);
            while (!q.empty()) {
                u = q.front(); q.pop();
                v = q.front(); q.pop();
                if (!u && !v) continue;
                if ((!u || !v) || (u->val != v->val)) return false;
    
                q.push(u->left); 
                q.push(v->right);
    
                q.push(u->right); 
                q.push(v->left);
            }
            return true;
        }
    
        bool isSymmetric(TreeNode* root) {
            return check(root, root);
        }
    };
    
    

    java

    class Solution {
        public boolean check(TreeNode u, TreeNode v){
            Queue<TreeNode> q = new LinkedList<TreeNode>();
            q.offer(u);//插入两个根节点
            q.offer(v);
            while(!q.isEmpty()){
                u = q.poll();
                v = q.poll();
                if(u == null && v == null ) continue;
                if( (u == null || v ==null) || (u.val != v.val) ) return false;
                q.offer(u.left);
                q.offer(v.right);
    
                q.offer(u.right);
                q.offer(v.left);
            }
            return true;
        }
        public boolean isSymmetric(TreeNode root) {
            return(check(root,root));
        }
    }
    

    参考

    作者:LeetCode-Solution
    链接:https://leetcode-cn.com/problems/symmetric-tree/solution/dui-cheng-er-cha-shu-by-leetcode-solution/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 相关阅读:
    std::type_index(转)
    __sync_fetch_and_add系列(转)
    InterlockedIncrement函数详解(转)
    如何让服务端同时支持WebSocket和SSL加密的WebSocket(即同时支持ws和wss)?(转)
    Linux系统管理基础测试
    CentOS7.7源码包安装Cmake3.0
    Shell-三剑客(sed)
    问题-突然发现公司网站访问速度变的很慢很慢
    Linux基础命令之文件及目录管理
    Linux基础命令之进程管理
  • 原文地址:https://www.cnblogs.com/PythonFCG/p/13860039.html
Copyright © 2011-2022 走看看