(검지 Offer) 면접 문제 19: 두 갈래 나무의 거울
1875 단어 면접 문제
제목:
주어진 두 갈래 트리를 조작하여 원본 두 갈래 트리의 거울로 변환합니다.
두 갈래 나무의 정의는 다음과 같다.
struct TreeNode{
int val;
TreeNode* left;
TreeNode* right;
};
설명 입력:
:
8
/ \
6 10
/ \ / \
5 7 9 11
8
/ \
10 6
/ \ / \
11 9 7 5
생각:
위의 두 갈래 나무를 관찰하면 아래에서 한 그루의 나무의 거울을 구하는 과정을 쉽게 얻을 수 있다.
먼저 이 나무의 모든 결점을 두루 훑어보고, 만약 두루 훑어보는 결점에 자결점이 있다면, 그 두 개의 자결점을 교환한다.모든 비잎결점의 좌우 결점을 교환한 후 나무의 거울을 얻었다.
코드:
struct TreeNode{
int val;
TreeNode* left;
TreeNode* right;
};
void Mirror(TreeNode *pRoot){
if(pRoot==NULL)
return;
if(pRoot->left==NULL && pRoot->right==NULL)
return;
TreeNode* tmp=pRoot->left;
pRoot->left=pRoot->right;
pRoot->right=tmp;
if(pRoot->left)
Mirror(pRoot->left);
if(pRoot->right)
Mirror(pRoot->right);
}
온라인 테스트 OJ:
http://www.nowcoder.com/books/coding-interviews/564f4c26aa584921bc75623e48ca3011?rp=1
AC 코드:
class Solution {
public:
void Mirror(TreeNode *pRoot){
if(pRoot==NULL)
return;
if(pRoot->left==NULL && pRoot->right==NULL)
return;
TreeNode* tmp=pRoot->left;
pRoot->left=pRoot->right;
pRoot->right=tmp;
if(pRoot->left)
Mirror(pRoot->left);
if(pRoot->right)
Mirror(pRoot->right);
}
};
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Java 프로그래머 면접에서의 다중 스레드 문제 요약wait ()/notify ()/notify All () 의 모든 방법을 호출할 때, 현재 라인이 이 대상의 자물쇠를 얻지 못하면, Illegal MonitorState Exception의 이상을 던집니다. Thre...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.