두 갈래 나무 뒷차례가 흐르는 비귀속 실현

카탈로그

  • 목록
  • 알고리즘 사상
  • 알고리즘 실현

  • 알고리즘 사상


    후순이 두 갈래 나무를 두루 돌아다니는 순서가 아니기 때문에 왼쪽 트리를 먼저 방문하고 오른쪽 트리를 방문하며 뿌리 노드를 방문한다.창고로 노드를 저장할 때 루트 노드를 구분해야 할 때 왼쪽 트리에서 돌아왔고 오른쪽 트리에서 돌아왔습니다.따라서 보조 포인터 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
    }

    좋은 웹페이지 즐겨찾기