Leetcode 701. 二叉搜索树中的插入操作

递归法:

首先考虑树为空的情况,只要返回一个值为val的结点即可;

当树不为空时,插入的算法为:

  1. 当val小于root.val,往下寻找左子树,即用root.left递归;
  2. 当val大于root.val(val值一定不等),往下寻找右子树,即用root.right递归;
  3. 直到找到一个null,说明可以在此插入值为val的结点了。

有两个地方需要去考虑,一是插入前记录父节点的位置,二是记录上一个递归是左儿子还是右儿子。父节点位置可以用一个全局变量记录一下;至于是左儿子还是右儿子可以用一个flag表示。在确定下一层是null时,把当前节点记录,并且把应插在左还是右也记录。

实现代码如下:

java 复制代码
class Solution {
 public TreeNode insertIntoBST(TreeNode root, int val) {
    	if(root==null) {
    		TreeNode ins = new TreeNode(val);
    		return ins;
    	}
    	insertBST(root,val);
    	return root;
    }
    
    int flag=0;//全局变量,0代表左儿子,1代表右儿子
    TreeNode father = new TreeNode();//全局变量记录父节点位置
    public void insertBST(TreeNode root,int val) {
    	if(root==null) {
    		TreeNode ins = new TreeNode(val);
    		if(flag==0) {
    			father.left=ins;
    		}else {
    			father.right=ins;
    		}
    		return;
    	}
    	if(val<root.val) {
    		if(root.left==null) {
    			father=root;
    		}
    		insertBST(root.left,val);
    	}
    	else {
    		if(root.right==null) {
    			father=root;
    			flag=1;
    		}
    		insertBST(root.right,val);
    	}
    }
}
相关推荐
Navigator_Z8 分钟前
LeetCode //C - 1031. Maximum Sum of Two Non-Overlapping Subarrays
c语言·算法·leetcode
Wect13 分钟前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·typescript
爱学习的张大25 分钟前
具身智能论文问答(三):Open VLA
人工智能·算法
wearegogog1231 小时前
基于Q-learning的栅格地图路径规划MATLAB仿真程序
开发语言·算法·matlab
旖-旎1 小时前
深搜练习(组合总和)(7)
c++·算法·深度优先·力扣
小O的算法实验室1 小时前
2026年ASOC,基于人工势场的差分进化算法改进框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
爱学习的张大1 小时前
具身智能论文精读(五):OpenVLA
人工智能·算法
逻辑驱动的ken2 小时前
Java高频面试场景题19
java·开发语言·面试·职场和发展·求职招聘
刘大猫.2 小时前
宝马发布全新AI智能座舱助手 能理解用户复杂出行需求
人工智能·算法·机器学习·ai·大模型·算力·ai智能座舱助手
如何原谅奋力过但无声2 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode