두 갈래 나무 뒷차례가 흐르는 비귀속 실현
1749 단어 두 갈래 나무두 갈래 나무가 뒤따라 두루 다니다비귀속 실현
카탈로그
알고리즘 사상
후순이 두 갈래 나무를 두루 돌아다니는 순서가 아니기 때문에 왼쪽 트리를 먼저 방문하고 오른쪽 트리를 방문하며 뿌리 노드를 방문한다.창고로 노드를 저장할 때 루트 노드를 구분해야 할 때 왼쪽 트리에서 돌아왔고 오른쪽 트리에서 돌아왔습니다.따라서 보조 포인터 r를 사용하여 최근에 방문한 노드를 가리킨다.노드에 접근했는지 여부를 기록하는 표지역을 추가할 수도 있습니다.
알고리즘 구현
//strcut TreeNode {
// ElemType data;
// TreeNode *left, *right;
// TreeNode() {
// left = right = NULL;
// }
//}
void PostOrder(TreeNode *root) {
TreeNode *p = root, *r = NULL;
stack s;
while (p || !s.empty()) {
if (p) {//
s.push(p);
p = p->left;
}
else {
p = s.top();
if (p->right && p->right != r)// ,
p = p->right;
else {
s.pop();
visit(p->val);
r = p;//
p = NULL;// , p
}
}//else
}//while
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
java 데이터 구조 2차원 트리의 실현 코드일.두 갈래 트리 인터페이스 2 노드 클래스 3. 두 갈래 나무 구현 이 글을 통해 여러분께 도움이 되었으면 좋겠습니다. 본 사이트에 대한 지지에 감사드립니다!...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.