Tree Traversals

非递归中序遍历

  1. Push 的顺序为先序遍历

  2. Pop 的顺序给出中序遍历


Sample Input:   

wKioL1X4F1HD88YRAAA5OTY5PD4112.jpg

6

Push 1

Push 2

Push 3

Pop

Pop

Push 4

Pop

Pop

Push 5

Push 6

Pop

Pop


wKiom1X4FZqg4Vr9AABoQGigYKQ580.jpg

void solve( int preL, int inL, int postL, int n )

    { if (n==0) return;

    if (n==1) {post[postL] = pre[preL]; return;}

    root = pre[preL];

    post[postL+n-1] = root;

        for (i=0; i<n; i++)

            if (in[inL+i] == root) break;

            L = i; R = n-L-1;

    solve(preL+1, inL, postL, L);

    solve(preL+L+1, inL+L+1, postL+L, R);

}


你可能感兴趣的:(tree,Traversals)