zoukankan      html  css  js  c++  java
  • 二叉搜索树与双向链表

    题目

      输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。比如输入下图中左边的二叉搜索树,则输出转换之后的排序双向链表

    思路

    • 每个结点都有两个指向子结点的指针。在双向链表中,每个结点也有两个指针,它们分别指向前一个结点和后一个结点。
    • 由于要求转换之后的链表是排好序的,我们可以中序遍历树中的每一个结点,这是因为中序遍历算法的特点是按照从小到大的顺序遍历二叉树的每一个结点。
    • 按照中序遍历的顺序,当我们遍历转换到根结点(值为10的结点)时,它的左子树已经转换成一个排序的链表了,并且处在链表中的最后一个结点是当前值最大的结点。我们把值为8的结点和根结点链接起来,此时链表中的最后一个结点就是10了。接着我们去遍历转换右子树,并把根结点和右子树中最小的结点链接起来
    /*
    struct TreeNode {
        int val;
        struct TreeNode *left;
        struct TreeNode *right;
        TreeNode(int x) :
                val(x), left(NULL), right(NULL) {
        }
    };*/
    class Solution {
    public:
        TreeNode* Convert(TreeNode* root)
        {
            if(root==nullptr)
                return nullptr;
            if(root->left==nullptr&&root->right==nullptr)
                return root;
            //1
            TreeNode *left=Convert(root->left);
            //2
            TreeNode *cur=left;
            while(cur&&cur->right)
                cur=cur->right;
            //3
            if(left)
            {
                cur->right=root;
                root->left=cur;
            }
            //4
            TreeNode *right=Convert(root->right);
            //5
            if(right)
            {
                right->left=root;
                root->right=right;
            }
            return left?left:root;
        }
    };
  • 相关阅读:
    html基本标签练习
    实践1-qq邮箱主页
    html加强
    Date日期操作
    日期类的加减及java中所以日期类的操作算法大全
    讲解java异常
    关于Java并发编程的总结和思考
    删除map、list集合元素总结
    Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】
    Java中的时间日期处理
  • 原文地址:https://www.cnblogs.com/tianzeng/p/10205861.html
Copyright © 2011-2022 走看看