leetcode--98.验证二叉搜索树、45.删除二叉搜索树中的节点、701.二叉搜索树中的插入操作

2024-02-17 02:48

本文主要是介绍leetcode--98.验证二叉搜索树、45.删除二叉搜索树中的节点、701.二叉搜索树中的插入操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

leetcode–98.验证二叉搜索树

题目:给定一个二叉树,判断其是否是一个有效的二叉搜索树。

假设一个二叉搜索树具有如下特征:

  • 节点的左子树只包含小于当前节点的数。
  • 节点的右子树只包含大于当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

leetcode链接

代码:

public boolean isValidBST(TreeNode root) {return func(root,null,null);
}
public boolean func(TreeNode root, Integer lower,Integer upper){if(root ==null )return true;int val=root.val;if(lower !=null && val<=lower) return false;if(upper!=null && val>=upper) return false;if(!func(root.right,val,upper)) return false;if(!func(root.left,lower,val)) return false;return true;
}

leetcode–45.删除二叉搜索树中的节点

题目:给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。

一般来说,删除节点可分为两个步骤:

  • 首先找到需要删除的节点;
  • 如果找到了,删除它。

思路:

  1. 如果 key > root.val,说明要删除的节点在右子树,root.right = deleteNode(root.right, key)。
  2. 如果 key < root.val,说明要删除的节点在左子树,root.left = deleteNode(root.left, key)。
  3. 如果 key == root.val,则该节点就是我们要删除的节点,则:
    • 如果该节点是叶子节点,则直接删除它:root = null。
    • 如果该节点不是叶子节点且有右节点,找到该节点右子树中最小的节点(最左下角的节点)
    • 如果该节点不是叶子节点且只有左节点,找到该节点左子树中最大的节点(最右下角的节点)
  4. 返回 root

代码:

public int letf(TreeNode root){root=root.left;while (root.right!=null){root=root.right;}return root.val;
}
public int right(TreeNode root){root=root.right;while (root.left!=null){root=root.left;}return root.val;
}
public TreeNode deleteNode(TreeNode root, int key) {if(root==null)return null;if(key>root.val){root.right=deleteNode(root.right,key);}else if(key< root.val){root.left=deleteNode(root.left,key);}else {if(root.left==null && root.right==null) root=null;else if(root.right!=null){root.val=right(root);root.right=deleteNode(root.right,root.val);}else {root.val=letf(root);root.left=deleteNode(root.left,root.val);}}return root;
}

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

题目:给定二叉搜索树(BST)的根节点和要插入树中的值,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 保证原始二叉搜索树中不存在新值。注意,可能存在多种有效的插入方式,只要树在插入后仍保持为二叉搜索树即可。 你可以返回任意有效的结果。
leetcode链接
思路:

  • 若 root == null,则返回 TreeNode(val)。
  • 若 val > root.val,插入到右子树。
  • 若 val < root.val,插入到左子树。
  • 返回 root。

代码:

public TreeNode insertIntoBST(TreeNode root, int val) {if(root==null) return new TreeNode(val);if(val>root.val){root.right=insertIntoBST(root.right,val);}else {root.left=insertIntoBST(root.left,val);}return root;
}

这篇关于leetcode--98.验证二叉搜索树、45.删除二叉搜索树中的节点、701.二叉搜索树中的插入操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/716448

相关文章

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3