老卫带你学---leetcode刷题(101. 对称二叉树)

101. 对称二叉树

问题:

给你一个二叉树的根节点 root , 检查它是否轴对称

bash 复制代码
输入:root = [1,2,2,3,4,4,3]
输出:true
bash 复制代码
输入:root = [1,2,2,null,3,null,3]
输出:false
bash 复制代码
提示:

树中节点数目在范围 [1, 1000] 内
-100 <= Node.val <= 100

解决:

要寻找对称,那只需要递归,然后让左右相等即可

go 复制代码
func isSymmetric(root *TreeNode) bool {
	if root == nil {
		return true
	}
	return dfs(root.Left, root.Right)
}

func dfs(l, r *TreeNode) bool {
	if l == nil && r == nil { //二者都是nil,对称返回true
		return true
	}
	if l == nil || r == nil { //二者有一个为nil,另一个非nil,返回false
		return false
	}
	if l.Val != r.Val {//二者值不同,返回false
		return false
	}
	return dfs(l.Left, r.Right) && dfs(l.Right, r.Left)
}
相关推荐
Shinom1ya_9 小时前
算法 day 41
数据结构·算法·leetcode
一匹电信狗10 小时前
【C++】红黑树详解(2w字详解)
服务器·c++·算法·leetcode·小程序·stl·visual studio
仰泳的熊猫12 小时前
LeetCode:72. 超级次方
数据结构·c++·算法·leetcode
_dindong13 小时前
牛客101:递归/回溯
数据结构·c++·笔记·学习·算法·leetcode·深度优先
刃神太酷啦13 小时前
力扣校招算法通关:双指针技巧全场景拆解 —— 从数组操作到环检测的高效解题范式
java·c语言·数据结构·c++·算法·leetcode·职场和发展
Shinom1ya_14 小时前
算法 day 42
数据结构·算法·leetcode
Dylan的码园15 小时前
以二叉树问题为基础的递归调试学习(上)
java·学习·算法·leetcode·r-tree
夏鹏今天学习了吗1 天前
【LeetCode热题100(56/100)】组合总和
算法·leetcode·职场和发展
微笑尅乐1 天前
三种方法解开——力扣3370.仅含置位位的最小整数
python·算法·leetcode
夏鹏今天学习了吗2 天前
【LeetCode热题100(57/100)】括号生成
算法·leetcode·职场和发展