今日算法(依旧二叉树)

cpp 复制代码
class Solution {
public:

    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        //递归进行,加回溯过程

        if(root==q||root==p||root==NULL) return root;
        TreeNode*left=lowestCommonAncestor(root->left,p,q);
         TreeNode*right=lowestCommonAncestor(root->right,p,q);
         if(left!=NULL&&right!=NULL) return root;//在左和右,返回根

         if(left==NULL&&right!=NULL) return right;
         else if(left!=NULL&&right==NULL) return left;
         else return NULL;

    }
};

普通二叉树,需要遍历全部,中左右遍历

思想:1.分别在左和右,根为祖先,2.p或q为根节点,直接返回p或q;3.都不在左,返回右;4.都不在右,返回左;

cpp 复制代码
class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        //比二叉树少了全图遍历//直接找根节点
        if(root==NULL) return root;

        
        if(root->val>p->val&&root->val>q->val) return lowestCommonAncestor(root->left,p,q);
        else if(root->val<p->val&&root->val<q->val) return lowestCommonAncestor(root->right,p,q);
        else return root;
    }
};

因为二叉搜索树是有序的,所以直接比较大小看在左右

1.都在左-》递归进行

2.都在右->递归

3.分别左右-》返回根;

cpp 复制代码
class Solution {
public:
    TreeNode* insertIntoBST(TreeNode* root, int val) {
        //需要保证树的平衡
        if(root==nullptr)
        {
            TreeNode*node=new TreeNode(val);
            return node;
        }
        if(root->val>val) root->left=insertIntoBST(root->left,val);
        if(root->val<val) root->right=insertIntoBST(root->right,val);

        return root;
    }
};

因为不用注意二叉树搜索树的性质,直接插入就行,比较查找,不用遍历全树;

cpp 复制代码
class Solution {
public:
    TreeNode* deleteNode(TreeNode* root, int key) {
        //1.节点不存在
        if(root==nullptr) return nullptr;

if(root->val==key)
{
        //2.节点左右为空
        if(root->left==nullptr&&root->right==nullptr)
        {
            delete root;
            return nullptr;
        }

        //3.节点左为空
        else if(root->left==nullptr)
        {
            //保存右节点返回
            TreeNode*node=root->right;
            delete root;
            return node;
        }

        //4.右节点为空
        else if(root->right==nullptr)
        {
            TreeNode*node=root->left;
            delete root;
            return node;
        }

        //左右不为空
        else
        {
            TreeNode*cur=root->right;
            //找右的最左节点
            while(cur->left)
            {
                cur=cur->left;
            }
            cur->left=root->left;
            TreeNode*tmp=root;
            root=root->right;
            delete tmp;
            return root;
        }
}
       if(root->val>key) root->left=deleteNode(root->left,key); 
       if(root->val<key) root->right=deleteNode(root->right,key); 

       return root;
    }
};

插入就比较麻烦,需要对删除节点进行分析,

1.不存在,返回空;

2.删除节点左右为空,直接删除,返回空

3.删除节点左节点不存在,直接右替代删除节点

4.删除节点右节点不存在,直接左替代删除节点

5.删除节点左右节点都存在,将删除节点的左节点放到删除节点的最左节点即可;

相关推荐
小欣加油8 分钟前
leetcode2161 根据给定数字划分数组
数据结构·c++·算法·leetcode·职场和发展
Momo__zz27 分钟前
零代码平台设计
算法·深度优先
cpp_250135 分钟前
P2947 [USACO09MAR] Look Up S
数据结构·c++·算法·题解·单调栈·洛谷
水木流年追梦1 小时前
大模型入门-大模型优化方法13- MTP 多 token 输出、DCA 双块注意力
人工智能·分布式·算法·正则表达式·prompt
数据皮皮侠1 小时前
全国消协智慧 315 平台投诉信息数据库
大数据·人工智能·算法·百度·制造
sbjdhjd1 小时前
面试题完结 | 投票题 + 到岗时间 + 压力缓解
经验分享·笔记·面试·职场和发展·开源·求职招聘·印象笔记
8Qi81 小时前
LeetCode 115 & 392:不同子序列 / 判断子序列
算法·leetcode·职场和发展·动态规划
小蒋学算法2 小时前
算法-乘法表中第K小的数-二分
数据结构·算法
智者知已应修善业2 小时前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19
c++·经验分享·笔记·算法·51单片机
Evand J2 小时前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可
开发语言·算法·matlab·目标跟踪·卡尔曼滤波·自适应滤波·代码定制