码迷,mamicode.com
首页 > 其他好文 > 详细

树的前序、中序、后续、层次遍历的递归和非递归解法

时间:2018-05-20 15:29:49      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:转化   back   思想   测试用例   out   tree   vector   tor   res   

老是忘记,这里做个记录。

//树的4种遍历方式的递归和非递归解法
void Preorder(TreeNode* root) {
    if (root == NULL)
        return;
    cout << root->val << endl;
    Preorder(root->left);
    Preorder(root->right);
}
void Inorder(TreeNode* root) {
    if (root == NULL)
        return;
    Inorder(root->left);
    cout << root->val << endl;
    Inorder(root->right);
}
void Postorder(TreeNode* root) {
    if (root == NULL)
        return;
    Postorder(root->left);
    Postorder(root->right);
    cout << root->val << endl;
}

//树的遍历非递归解法
void Preorder2(TreeNode* root) {
    stack<TreeNode*> s;
    s.push(root);
    while (!s.empty()) {
        TreeNode * t = s.top();
        s.pop(); 
        cout << t->val << endl;
        if (t->right != NULL) s.push(t->right);
        if (t->left != NULL) s.push(t->left);
    }
}
void Preorder3(TreeNode* root) {
    stack<TreeNode*> s;
    while (root != NULL || !s.empty()) {
        if (root != NULL) {
            cout << root->val << endl;
            s.push(root);
            root = root->left;
        }else {
            root = s.top()->right;
            s.pop();
        }
    }
}
void Inorder2(TreeNode* root) {
    stack<TreeNode*> s;
    while (root != NULL || !s.empty()) {
        if (root != NULL) {
            s.push(root);
            root = root->left;
        }
        else {
            cout << s.top()->val << endl;
            root = s.top()->right;
            s.pop();
        }
    }
}
void Postorder2(TreeNode* root) {
    stack<TreeNode*> s;
    TreeNode* pre = NULL;
    while (!s.empty()) {
        TreeNode* t = s.top();
        if ((t->left == NULL && t->right == NULL) || (pre != NULL && (pre == t->left || pre == t->right))) {
            cout << t->val << endl;
            s.pop();
            pre = t;
        }
        else {
            if (t->right != NULL)
                s.push(t->right);
            if (t->left != NULL)
                s.push(t->left);
        }
    }
}

//层次遍历的递归解法,实际上还是利用的dfs的思想,对层次相等的节点进行输出
void dfs(vector<vector<int>>& result,int level,TreeNode* root) {
    if (root == NULL) return;
    while (result.size() <= level)
        result.emplace_back(vector<int>());
    result[level].emplace_back(root->val);
    dfs(result, level + 1, root->left);
    dfs(result, level + 1, root->right);
}
void Levelorder2(TreeNode* root) {
    vector<vector<int>> result;
    dfs(result,0,root);
    for (auto i : result)
        for (auto j : i)
            cout << j << endl;
}

void dfs_out(TreeNode* root,int level, int target) {
    if (root == NULL) return;
    if (level == target)
        cout << root->val << endl;
    dfs_out(root->left, level + 1, target);
    dfs_out(root->right, level + 1, target);
}
int depth(TreeNode* root) {
    if (root == NULL) return 0;
    return max(depth(root->left), depth(root->right)) + 1;
}
void Levelorder3(TreeNode* root) {
    int d = depth(root);
    for (int i = 0; i < d; i++) {
        dfs_out(root, 0, i);
    }
}

//这是测试用例
//while循环退出条件的时候转化成for时来看
int main()
{
    TreeNode t1(1);
    TreeNode t2(2);
    TreeNode t3(3);
    TreeNode t4(4);
    TreeNode t5(5);
    TreeNode t6(6);
    TreeNode t7(7);
    TreeNode t8(8);
    TreeNode t9(9);
    TreeNode t10(10);
    TreeNode t11(11);

    t1.left = &t2;
    t1.right = &t3;
    t2.left = &t4;
    t2.right = &t5;
    t3.left = &t6;
    t3.right = &t7;
    t5.left = &t8;
    t5.right = &t9;
    t9.left = &t10;
    t9.right = &t11;
    Levelorder3(&t1);

    system("pause");
    return 0;
}

 

树的前序、中序、后续、层次遍历的递归和非递归解法

标签:转化   back   思想   测试用例   out   tree   vector   tor   res   

原文地址:https://www.cnblogs.com/likaiming/p/9063286.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!