判断对称树。题意是给一个树,判断它是不是左右对称/轴对称的。例子
For example, this binary tree
[1,2,2,3,4,4,3]
is symmetric:1 / \ 2 2 / \ / \ 3 4 4 3
But the following
[1,2,2,null,3,null,3]
is not:1 / \ 2 2 \ \ 3 3
题目很简单,跟100题几乎一样,也是用DFS思路做。唯一不同的地方是当判断子树的时候,100题是判断left.left == right.left;而这题是判断left.right == right.left
时间O(n)
空间O(n)
JavaScript实现
1 /** 2 * @param {TreeNode} root 3 * @return {boolean} 4 */ 5 var isSymmetric = function(root) { 6 if (root === null) return true; 7 return helper(root.left, root.right); 8 }; 9 10 var helper = function(left, right) { 11 if (left === null && right === null) return true; 12 if (left === null || right === null) return false; 13 if (left.val !== right.val) return false; 14 return helper(left.left, right.right) && helper(left.right, right.left); 15 };
Java实现
1 class Solution { 2 public boolean isSymmetric(TreeNode root) { 3 if (root == null) 4 return true; 5 return helper(root.left, root.right); 6 } 7 8 private boolean helper(TreeNode p, TreeNode q) { 9 if (p == null && q == null) 10 return true; 11 if (p == null || q == null) 12 return false; 13 if (p.val != q.val) 14 return false; 15 return helper(p.left, q.right) && helper(p.right, q.left); 16 } 17 }
BFS解法
时间O(n)
空间O(n)
JavaScript实现
1 /** 2 * @param {TreeNode} root 3 * @return {boolean} 4 */ 5 var isSymmetric = function(root) { 6 const q = [root, root]; 7 while (q.length) { 8 const [l, r] = [q.shift(), q.shift()]; 9 if (!l && !r) continue; 10 if (!!l !== !!r || l.val !== r.val) return false; 11 q.push(l.left, r.right, l.right, r.left); 12 } 13 return true; 14 };