LeetCode 매일 1문제: 대칭 두 갈래 나무
문제 설명
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For example, this binary tree is symmetric: 1/ 2 2/\/ 3 4 4 3
But the following is not: 1/ 2 2\ 3 3
Note: Bonus points if you could solve it both recursively and iteratively.
문제 분석
나무 한 그루가 대칭적인지 아닌지를 구하려면 한 노드에 대해 두 아이가 같다는 것을 만족시켜야 한다. 그리고 왼쪽 아이의 왼쪽 아이와 오른쪽 아이의 오른쪽 아이가 같고 왼쪽 아이의 오른쪽 아이가 오른쪽 아이의 왼쪽 아이와 같다는 것을 만족시켜야 한다. 귀속으로 하면 된다.
코드 구현
public boolean isSymmetric(TreeNode root) {
if (root == null) return true;
return isSymmetricHelper(root.left, root.right);
}
private boolean isSymmetricHelper(TreeNode leftChild, TreeNode rightChild) {
if (leftChild == null && rightChild == null) return true;
if (leftChild == null && rightChild != null) return false;
if (leftChild != null && rightChild == null) return false;
if (leftChild.val != rightChild.val) return false;
return isSymmetricHelper(leftChild.left, rightChild.right) && isSymmetricHelper(leftChild.right, rightChild.left);
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.