IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 二叉树的对称问题 -> 正文阅读

[数据结构与算法]二叉树的对称问题

1. 对称二叉树

在这里插入图片描述

对称二叉树

思路:
1.先将根节点的左右节点入队。
2.出队,比较两个节点的值是否相等
3.若相等,则当前左节点的左节点入队,当前右节点的右节点入队,当前左节点的右节点入队,当前右节点的左节点入队。若不相等,返回false。
4.注意:当节点为空时,跳出此次循环。。。。。。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isSymmetric(TreeNode root) {
        Queue<TreeNode> queue = new LinkedList<>();//存放节点
        
        queue.offer(root.left);
        queue.offer(root.right);

        while(!queue.isEmpty()){
            TreeNode Lnode = queue.poll();
            TreeNode Rnode = queue.poll();
            if(Lnode==null&&Rnode==null) continue;
            if(Lnode==null&&Rnode!=null) return false;
            if(Lnode!=null&&Rnode==null) return false;
            if(Lnode.val!=Rnode.val) return false;
            // 两个节点值相等
            queue.offer(Lnode.left);  //外层
            queue.offer(Rnode.right);//外层

            queue.offer(Lnode.right);//内层
            queue.offer(Rnode.left);//内层
        }
        return true;//当不满足循环时,返回true

    }
}

2.相同的树

在这里插入图片描述
相同的树

思路:
1.若两棵树不为空,将两棵树的根节点入队
2.若值相等,将p树的左节点入队,q树的左节点入队,p树的右节点入队,q树的右节点入队。
3.若当时左右根节点均为null,说明已经遍历完成,则退出本次循环

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isSameTree(TreeNode p, TreeNode q) {
        //先判断根节点是否为空
        if(p==null&&q==null) return true;
        if(p==null||q==null) return false;
        //根节点不为空
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(p);
        queue.offer(q);

        while(!queue.isEmpty()){
            //注意取出结点,否则造成死循环
            TreeNode Lnode = queue.poll();//取出根节点
            TreeNode Rnode = queue.poll();

            if(Lnode==null&&Rnode!=null) return false;
            if(Lnode!=null&&Rnode==null) return false;
            if(Lnode==null&&Rnode==null) continue;
            if(Lnode.val!=Rnode.val) return false;

            //节点不为空,且值相等
            queue.offer(Lnode.left);
            queue.offer(Rnode.left);
            queue.offer(Lnode.right);
            queue.offer(Rnode.right);
        }
        return true;
    }
}

3.另一棵树的子树

在这里插入图片描述
另一棵树的子树

双重递归

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isSubtree(TreeNode root, TreeNode subRoot) {
        
         if(root==null &&subRoot ==null) return true;
         if(root==null||subRoot==null) return false;
         
         //根节点不为空
         Queue<TreeNode> queue = new LinkedList<>();
         queue.offer(root); //根节点入队
         while(!queue.isEmpty()){
            TreeNode temp = queue.poll();//取出根节点

            if(isSame(temp,subRoot)) return true;
            //如果是false,继续遍历
            if(temp.left!=null) queue.add(temp.left);
            
            if(temp.right!=null) queue.add(temp.right);
         }
         return false;
                 
    }

    public boolean isSame(TreeNode node1,TreeNode node2){
        if(node1==null&&node2==null) return true;
        if(node1==null||node2==null||node1.val!=node2.val) return false;
        //当前节点不为空且值相等,继续遍历
        return isSame(node1.left,node2.left)&&isSame(node1.right,node2.right);
    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-02-26 11:55:08  更:2022-02-26 12:01:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 15:24:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码