今日算法(依旧二叉树)

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.删除节点左右节点都存在,将删除节点的左节点放到删除节点的最左节点即可;

相关推荐
Zxc_2 小时前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法
阿Y加油吧2 小时前
两道经典动态规划题:乘积最大子数组 & 分割等和子集 复盘笔记
笔记·算法·动态规划
三品吉他手会点灯2 小时前
C语言学习笔记 - 33.数据类型 - printf函数的详细用法
c语言·开发语言·笔记·学习·算法
NashSKY3 小时前
PnP 问题:数学描述与 DLT 算法推导
算法·矩阵分解·多视图几何·射影几何
csdn_aspnet3 小时前
C++ Lomuto分区算法(Lomuto Partition Algorithm)
开发语言·c++·算法
ZPC82103 小时前
Open3D 与yolo-3d 那个更适合生成物体3d 包围盒
人工智能·算法·计算机视觉·机器人
行走的陀螺仪3 小时前
JavaScript 算法详解:10大经典算法,通俗易懂,从入门到精通
开发语言·javascript·算法
1368木林森4 小时前
RAG查询改写②【第十篇】:HYDE、StepBack、子问题拆分,高阶改写算法生产落地
人工智能·算法·rag
smj2302_796826524 小时前
解决leetcode第3934题最短唯一子数组
数据结构·python·算法·leetcode