代码随想录训练第十七天| 654.最大二叉树 、617.合并二叉树、700.二叉搜索树中的搜索、 98.验证二叉搜索树

一、最大二叉树

题目链接/文章讲解: 代码随想录

1.这题并不难,和昨天那道题思路差不多,找到根节点,分割数组,递归,返回节点,赋值给节点的左右指针。

代码:

class Solution {
public:
    TreeNode* Traversal(vector<int>& nums)
    {
        if(nums.empty()) return nullptr;
        //求最大值的下标
        auto maxPosition = max_element(nums.begin(), nums.end());
        int index=maxPosition - nums.begin();
        TreeNode *temp=new TreeNode(nums[index]);
        //切割数组,左闭右开
        vector<int> nums1(nums.begin(),nums.begin()+index);
        vector<int> nums2(nums.begin()+index+1,nums.end());

        temp->left=Traversal(nums1);
        temp->right=Traversal(nums2);
        return temp;
    }
    TreeNode* constructMaximumBinaryTree(vector<int>& nums) {
        TreeNode* root=Traversal(nums);
        return root;
    }
};

二、合并二叉树

题目链接/文章讲解: 代码随想录

 1.本题没做出来的主要原因是终止条件没有思考清楚。

代码:

class Solution {
public:
    TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {
        //终止条件 其中一个为空,如果一方为空,直接接上另一方的子树
        //两个都为空,返回空
        if(!root1)  return root2;
        if(!root2)  return root1;

        root1->val+=root2->val;
        root1->left=mergeTrees(root1->left,root2->left);
        root1->right=mergeTrees(root1->right,root2->right);

        return root1;
    }
};

三、二叉搜索树中的搜索

题目链接/文章讲解: 代码随想录

1.不难,利用二叉搜索树的特性,递归法,找到目标节点,返回子树即可

代码:

class Solution {
public:
    
    TreeNode* searchBST(TreeNode* root, int val) {
        TreeNode* res;
        //遍历结束了,找不到了
        if(!root)  return nullptr;

        if(root->val>val)
        {
            res=searchBST(root->left,val);
        }
        else if(root->val<val)
        {
            res=searchBST(root->right,val);
        }
        //如果找到了,马上返回
        else
        return res=root;
        return res;
    }
};

四、验证二叉搜索树

题目链接/文章讲解: 代码随想录

1.做的时候中陷阱了:不能单纯的比较左节点小于中间节点,右节点大于中间节点

                  我们要比较的是 左子树所有节点小于中间节点,右子树所有节点大于中间节点

2.样例中最小节点 可能是int的最小值,如果这样使用最小的int来比较也是不行的。

3.第一次用中序遍历做题目,左中右,中取值与前一个节点进行判断大小

代码:

class Solution {
public:
    TreeNode* pre = NULL; // 用来记录前一个节点
    bool isValidBST(TreeNode* root) {
        if (root == NULL) return true;
        bool left = isValidBST(root->left);

        if (pre != NULL && pre->val >= root->val) return false;
        pre = root; // 记录前一个节点

        bool right = isValidBST(root->right);
        return left && right;//左右子树都要是搜索二叉树,不然返回false
    }
};

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值