Day20——最大二叉树、合并二叉树、二叉搜索树中的搜索、验证二叉搜索树

简介: Day20——最大二叉树、合并二叉树、二叉搜索树中的搜索、验证二叉搜索树

前言


今日文案:

猫喜欢吃鱼,猫却不能下水,鱼喜欢吃蚯蚓,鱼却不能上岸,人生,就是一边拥有,一边失去,一边选择,一边放弃。

一、最大二叉树


力扣

解题思路:


主要也是分割数组思想。

class Solution {
public:
    TreeNode* constructMaximumBinaryTree(vector<int>& nums) {
        TreeNode*root=new TreeNode(0);
        if(nums.size()==1)
        {
            root->val=nums[0];        //数组只有一个数的时候,可以直接返回
            return root;
        }
        int max=-100,maxindex=0;    
        for(int i=0;i<nums.size();i++)        //遍历数组
        {
            if(nums[i]>max)                //找出最大值及其下标
            {
                max=nums[i];
                maxindex=i;
            }
        }
        root->val=max;        //建好中节点数值
        if(maxindex>0)        //判断左子树是否有元素
        {
            vector<int> lefttree(nums.begin(),nums.begin()+maxindex);
            root->left=constructMaximumBinaryTree(lefttree);
        }
        if(maxindex<nums.size()-1)          //判断右子树是否有元素
        {
            vector<int> righttree(nums.begin()+maxindex+1,nums.end());
            root->right=constructMaximumBinaryTree(righttree);
        }
        return root;
    }
};

二、合并二叉树


力扣

解题思路:


同时遍历两棵树,同一位置都有就加起来,有空就用另外一棵树补。构造一般用前序。

class Solution {
public:
    TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {
        if(root1==NULL)            //一个有空就返回另外一个
        {
            return root2;
        }
        if(root2==NULL)
        {
            return root1;
        }
        TreeNode*node=new TreeNode(0);        //建立节点
        node->val=root1->val+root2->val;        //都有就加起来
        node->left=mergeTrees(root1->left,root2->left);    //遍历
        node->right=mergeTrees(root1->right,root2->right);
        return node;
    }
};

三、二叉搜索树中的搜索


力扣

class Solution {
public:
    TreeNode* searchBST(TreeNode* root, int val) {
        if(root==NULL)             
        {
            return NULL;
        }
        if(root->val==val)        //找到了就返回
        {
            return root;
        }
        if(root->left==NULL&&root->right==NULL)        //叶子节点也返回
        {
            return NULL;
        }
        TreeNode*node=NULL;            //创建节点存值
        if(val>root->val)            //根据搜索树的定义,分两边搜索
        {
            node=searchBST(root->right,val);
        }
        if(val<root->val)
        {
            node=searchBST(root->left,val);
        }
        return node;
    }
};

四、验证二叉树搜索


class Solution {
public:
    long long maxval=LONG_MIN;        //设定最小值
    bool isValidBST(TreeNode* root) {
        if(root==0)
        {
            return true;                    //空节点就返回
        }
        bool left=isValidBST(root->left);        //左遍历
        if(maxval<root->val)            //一层一层赋值,递增
        {
            maxval=root->val;
        }
        else                //有违法的直接false,就再也没有机会翻身了。
        {
            return false;
        }
        bool right=isValidBST(root->right);    
        return right&&left;
    }
};

总结


感觉囫囵吞枣,好烦,感觉还是没有分清楚,前中后序遍历的过程,贪多嚼不烂了。

相关文章
|
2天前
|
数据采集 人工智能 安全
|
11天前
|
云安全 监控 安全
|
3天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1014 151
|
3天前
|
编解码 人工智能 机器人
通义万相2.6,模型使用指南
智能分镜 | 多镜头叙事 | 支持15秒视频生成 | 高品质声音生成 | 多人稳定对话
|
16天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1709 9
|
8天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
652 152
|
10天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
618 12
|
10天前
|
人工智能 自然语言处理 API
Next AI Draw.io:当AI遇见Draw.io图表绘制
Next AI Draw.io 是一款融合AI与图表绘制的开源工具,基于Next.js实现,支持自然语言生成架构图、流程图等专业图表。集成多款主流大模型,提供智能绘图、图像识别优化、版本管理等功能,部署简单,安全可控,助力技术文档与系统设计高效创作。
689 151