数据结构 Java数据结构 --- 二叉搜索树

在这里插入图片描述

2. 二叉树操作 - 查找

=================================================================================

在这里插入图片描述

代码实现:

public Node search(int val){

while (root != null){

if(val > root.val){// val>root.val 在右子树查找

root = root.right;

}else if(val < root.val){// val<root.val 在左子树查找

root = root.left;

}else {// val=root.val 返回该节点即可

return root;

}

}

return null;

}

3. 二叉树操作 - 插入

=================================================================================

在这里插入图片描述

代码实现:

public boolean insert(int val) {

// 当为空树的时候 直接插入val

if(root == null) {

root = new Node(val);

return true;

}

// 当不为空时的时候,进行判断

Node parent = null;

Node child = root;

while (child != null){

// val 较大 寻找右子树

if(child.val < val){

parent = child;

child = child.right;

}else {//val 较小 寻找左子树

parent = child;

child = child.left;

}

}

// 这里 parent的左子树或右子树就可以进行插入,此时进行判断.

if(parent.val < val){

parent.right = new Node(val);

}else {

parent.left = new Node(val);

}

return true;

}

4. 二叉树操作 - 删除

=================================================================================

在这里插入图片描述

在这里插入图片描述

public void remove(int key) {

Node cur = root;

Node parent = null;

while (cur != null){

if(cur.val == key){

//找到要删除的节点 进行删除

removeNode(cur,parent);

}else if(cur.val < key){

parent = cur;

cur = cur.right;

}else {

parent = cur;

cur = cur.left;

}

}

}

public void removeNode(Node cur,Node parent){

if(cur.left == null){ // 情况一

if(cur == root){

root = cur.right;

}else if(cur == parent.left){

parent.left = cur.right;

}else {

parent.right = cur.right;

}

}else if(cur.right == null){ // 情况二

if(cur == root){

root = cur.left;

}else if(cur == parent.right){

parent.right = cur.left;

}else {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

那么如何才能正确的掌握Redis呢?

为了让大家能够在Redis上能够加深,所以这次给大家准备了一些Redis的学习资料,还有一些大厂的面试题,包括以下这些面试题

  • 并发编程面试题汇总

  • JVM面试题汇总

  • Netty常被问到的那些面试题汇总

  • Tomcat面试题整理汇总

  • Mysql面试题汇总

  • Spring源码深度解析

  • Mybatis常见面试题汇总

  • Nginx那些面试题汇总

  • Zookeeper面试题汇总

  • RabbitMQ常见面试题汇总

JVM常频面试:

Redis高频面试笔记:基础+缓存雪崩+哨兵+集群+Reids场景设计

Mysql面试题汇总(一)

Redis高频面试笔记:基础+缓存雪崩+哨兵+集群+Reids场景设计

Mysql面试题汇总(二)

Redis高频面试笔记:基础+缓存雪崩+哨兵+集群+Reids场景设计

Redis常见面试题汇总(300+题)

Redis高频面试笔记:基础+缓存雪崩+哨兵+集群+Reids场景设计
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
12012534)]

Mysql面试题汇总(二)

[外链图片转存中…(img-sgqyOeMt-1713712012534)]

Redis常见面试题汇总(300+题)

[外链图片转存中…(img-qiIhern9-1713712012534)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值