101. 对称二叉树 ----- 二叉树、递归、迭代、队列
给你一个二叉树的根节点 root , 检查它是否轴对称。
示例 1:
输入:root = [1,2,2,3,4,4,3]
输出:true
示例 2:
输入:root = [1,2,2,null,3,null,3]
输出:false
提示:
树中节点数目在范围 [1, 1000] 内
-100 <= Node.val <= 100
进阶:你可以运用递归和迭代两种方法解决这个问题吗?
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/symmetric-tree
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
递归:
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { bool Treeis(TreeNode* left, TreeNode* right) { if (!left && !right) return true; if (!left || !right) return false; return( (left -> val == right -> val) && Treeis(left -> left, right ->right) && Treeis (left -> right, right -> left) ); } public: bool isSymmetric(TreeNode* root) { return Treeis (root -> left, root -> right); } };
迭代:
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: bool check(TreeNode *left, TreeNode *right) { queue <TreeNode*> q; // 引入队列 q.push(left); q.push(right); // 将两个节点入队 while (!q.empty()) { // 如果队列非空 left = q.front(); q.pop(); // 每一次出队比较两个节点 right = q.front(); q.pop(); if (!left && !right) continue; // 如果两个节点都为空,跳出循环 if ((!left || !right) || (left->val != right->val)) return false; // 如果只有一方为空或者左右不相等就返回false q.push(left->left); // 按照对称的顺序入队 q.push(right->right); q.push(left->right); q.push(right->left); } return true; } bool isSymmetric(TreeNode* root) { return check(root, root); } };
hello my world
本文来自博客园,作者:slowlydance2me,转载请注明原文链接:https://www.cnblogs.com/slowlydance2me/p/16886785.html
分类:
Leecode做题记录
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理