LeetCode【701】二叉搜索数的插入操作

题目:

思路:

https://zhuanlan.zhihu.com/p/272781596

代码:

java 复制代码
class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
         return process(root,val);   
    }
		//递归
    public TreeNode process(TreeNode root,int val){
    	//base case  来到null 位置,创建出节点
        if(root == null){
            return new TreeNode(val);
        }
        //寻找创建的位置,
        if(root.val > val){
            root.left = process(root.left,val);

        }
         //寻找创建的位置,
        if(root.val < val){
            root.right = process(root.right,val);
        }
        return root;    // 这里是精妙之处,其实遍历的过程中,返回了root,对于普通节点,入传入的root.left,返回仍然是root.left
    }
}
相关推荐
半壶清水12 分钟前
[软考网规考点笔记]-操作系统核心知识及历年真题解析
网络·网络协议·算法
Tansmjs25 分钟前
实时数据可视化库
开发语言·c++·算法
WBluuue28 分钟前
Codeforces 1075 Div2(ABC1C2D1D2)
c++·算法
圣保罗的大教堂28 分钟前
leetcode 3650. 边反转的最小路径总成本 中等
leetcode
2401_838472511 小时前
C++模拟器开发实践
开发语言·c++·算法
s1hiyu1 小时前
实时控制系统验证
开发语言·c++·算法
daad7771 小时前
V4L2_mipi-csi
算法
2301_765703141 小时前
C++代码复杂度控制
开发语言·c++·算法
m0_708830961 小时前
C++中的享元模式实战
开发语言·c++·算法
naruto_lnq1 小时前
分布式计算C++库
开发语言·c++·算法