博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode-Symmetric Tree
阅读量:5093 次
发布时间:2019-06-13

本文共 2085 字,大约阅读时间需要 6 分钟。

树的遍历,

递归:

1 /** 2  * Definition for binary tree 3  * struct TreeNode { 4  *     int val; 5  *     TreeNode *left; 6  *     TreeNode *right; 7  *     TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8  * }; 9  */10 class Solution {11 public:12     bool isSymmetric(TreeNode *root) {13         // Start typing your C/C++ solution below14         // DO NOT write int main() function15         if (root == NULL)16             return true;17         return symmetric(root->left, root->right);18     }19     bool symmetric(TreeNode *lnode, TreeNode *rnode) {20         if (lnode == NULL && rnode == NULL)21             return true;22         if (lnode == NULL || rnode == NULL) 23             return false;24         if (lnode->val != rnode->val) {25             return false;26         }27         return symmetric(lnode->left, rnode->right) && symmetric(lnode->right, rnode->left);28     }29 };

迭代要用到队列;

1 /** 2  * Definition for binary tree 3  * struct TreeNode { 4  *     int val; 5  *     TreeNode *left; 6  *     TreeNode *right; 7  *     TreeNode(int x) : val(x), left(NULL), right(NULL) {} 8  * }; 9  */10 class Solution {11 public:12     bool isSymmetric(TreeNode *root) {13         // Start typing your C/C++ solution below14         // DO NOT write int main() function15         if (root == NULL)16             return true;17         queue
tqueue;18 tqueue.push(root->left);19 tqueue.push(root->right);20 while (!tqueue.empty()) {21 TreeNode *lnode = tqueue.front();22 tqueue.pop();23 TreeNode *rnode = tqueue.front();24 tqueue.pop();25 if (lnode == NULL && rnode == NULL)26 continue;27 if (lnode == NULL || rnode == NULL || (lnode->val != rnode->val))28 return false;29 tqueue.push(lnode->left);30 tqueue.push(rnode->right);31 tqueue.push(lnode->right);32 tqueue.push(rnode->left);33 }34 return true;35 }36 };

 

转载于:https://www.cnblogs.com/chasuner/p/symmetic.html

你可能感兴趣的文章
Codeforces 719B Anatoly and Cockroaches
查看>>
jenkins常用插件汇总
查看>>
c# 泛型+反射
查看>>
第九章 前后查找
查看>>
Python学习资料
查看>>
jQuery 自定义函数
查看>>
jquery datagrid 后台获取datatable处理成正确的json字符串
查看>>
ActiveMQ与spring整合
查看>>
web服务器
查看>>
第一阶段冲刺06
查看>>
EOS生产区块:解析插件producer_plugin
查看>>
JS取得绝对路径
查看>>
排球积分程序(三)——模型类的设计
查看>>
HDU 4635 Strongly connected
查看>>
格式化输出数字和时间
查看>>
页面中公用的全选按钮,单选按钮组件的编写
查看>>
java笔记--用ThreadLocal管理线程,Callable<V>接口实现有返回值的线程
查看>>
(旧笔记搬家)struts.xml中单独页面跳转的配置
查看>>
不定期周末福利:数据结构与算法学习书单
查看>>
strlen函数
查看>>