网站建设 怎么设置在线客服/百度网络营销中心官网

网站建设 怎么设置在线客服,百度网络营销中心官网,网站开发的全套软件,公司发展规划怎么写1. 搜索树 1.1 概念 二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树: 若它的左子树不为空,则左子树上所有的结点都小于根结点的值若它的右子树不为空,则右子树上所有的结点都大于根结点的值…

1. 搜索树

1.1 概念

二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树:

  • 若它的左子树不为空,则左子树上所有的结点都小于根结点的值
  • 若它的右子树不为空,则右子树上所有的结点都大于根结点的值
  • 它的左右子树也都分别是二叉搜索树

如下图,就是一棵二叉搜索树,二叉搜索树的中序遍历就是升序排列的

1.2 操作-查找

因为二叉搜索树天然就带有小的在左,大的在右的顺序,所以在查找的时候更加方便,类似于有天然的二分查找

代码实现如下:

1.3 操作 - 插入

按照二叉搜索树,小的在左边,大的在右边逻辑确定插入位置,插入新结点。因为要插入的结点最终都是称为叶子结点,所以光定义一个cur来表示要插入的结点还不够,还要定义一个parent结点来表示cur的父亲结点。

代码如下:

但上面代码的逻辑性还是有问题的,插入操作,并没有考虑到,如果要插入的树是一棵空树,即root == null的情况,会出现空指针的异常。

修正:

1.4 操作 - 删除(难)

搜索二叉树的删除是会发生很尴尬的情况的

如下图:

如果要删除值为8的结点,是很方便的,可以将7结点的right连接到值为9的结点。

但如果删除的是左边的值为1的结点呢?

删除了之后,3的left是连接值为2的结点呢?还是连接值为0的结点呢?这样就会出现尴尬的情况,采用的方法是替换法(也称替罪羊法),即可以在要删除的结点的右子树中,寻找一个值最小的叶子节点,换个方式讲是,找到要删除的结点的右子树的最左边子树(有点绕,可以多多理解一下),然后用这个最左边子树的值来覆盖要删除的结点的值,然后将最左边子树的结点删除。注意是覆盖,并不是将要删除的结点真的删除了,最终删除的结点是要删除的结点的右子树的最左边子树的结点。

举例:

如果要删除的结点是值为90的结点

先找到90结点的右子树为值为120的结点,然后再找到右子树120的最左边子树,即值为95的结点,用这个结点的值95来覆盖掉要删除的结点90的值,然后删除值为95的这个结点,如何删除呢?如果值为95的这个结点仍有有右子树呢?(注意:值为95的这个结点不可能再有左子树了,因为我们要在前面的操作中找的就是 要删除的结点的右子树的最左子树)就把值为95的结点的右子树连接到值为120的结点的left上即可。

(上面只是一种方式,是找到 要删除结点 的 右子树 的最左侧子树,同理, 也可以找到 要删除的结点 的 左子树 的最右侧子树,都相反一下即可,此处以右子树的最左侧左子树来研究)

代码实现:

设待删除结点为cur,带删除结点的双亲结点为parent

在删除中,有多种情况:

1.1情况:cur为root 且 cur.left == null 如下图,此时直接将cur的left赋值为root即可

删除后的效果:

1.2情况:cur不是root,cur.left == null,cur在左子树上,即cur 是 parent.left 如下图的效果,此时要删除的结点是值为40的结点,直接parent.left = cur.right即可

1.3 情况:cur不是root,cur.left == null cur是parent.right,即cur在右子树上,如下图情况,则直接parent.right = cur.right即可

2.1情况 cur.right == null cur是root 则直接root = cur.left即可

2.2情况:cur不是root cur是parent.left  且cur.right == null 则parent .left = cur.left

2.3 cur不是root cur是parent.right 且cur.right == null 则parent.right = cur.left


即使用前面所述的替代法。

代码实现如下:

下面的代码实现是前面的删除逻辑

替代法因为要向下找到要删除结点 的 右边子树 的 最左边子树,所以还需要一个寻找的逻辑,定义一个targetParent和target来寻找找最左子树

当结束上面的while循环时候,即target指向的是最左子树结点,然后cur.val = target.val进行覆盖

如下图所示:要删除的结点是cur,t是要删除节点 的 右边结点 的 最左侧结点,将cur的值覆盖为95,然后将 t 结点删掉(targetParent.left = target.right)(注意:删除的时候不要直接targetParent.left = null 因为target可能有右节点 也可能 没有右节点)

则代码如下:

但上面代码还是存在逻辑漏洞

如果是下图的情况,cur为值为95的结点,在while循环结束后,t指向的是值为120的结点,直接执行targetParent.left = target.right 就乱套了

所以还应该加一个 if 条件 即:if(taregt == targeParent.left)的时候,才能targetParent.left = target.right;否则应该是targetParent.right = target.right;

则替代法的实现代码应该是:

完整的删除代码如下:

 public void remove(int val) {TreeNode cur = root;TreeNode parent = null;while(cur != null) {if(val < cur.val) {parent = cur;cur = cur.left;} else if(val > cur.val) {parent = cur;cur = cur.right;} else {//删除的逻辑removeNode(parent,cur);return;}}}private void removeNode(TreeNode parent, TreeNode cur) {if(cur.left == null) {if(cur == root) {root = cur.right;} else if(cur == parent.right) {parent.right = cur.right;} else {parent.left = cur.right;}} else if(cur.right == null) {if(cur == root) {root = cur.left;} else if(cur == parent.right) {parent.right = cur.left;} else {parent.left = cur.left;}} else {//替代法:TreeNode targetParent = cur;TreeNode target = cur.right;while(target.left != null) {targetParent = target;target = target.left;}cur.val = target.val;if(targetParent.left == target) {targetParent.left = target.right;} else {targetParent.right = target.right;}}}

1.5 性能分析:

插入和删除的操作都必须先查找,所以查找的效率可以代表二叉搜索树中各个操作的性能。

对有n个结点的二叉搜索树,若每个元素查找的概率相等,则二叉搜索树平均查找商都是结点在二叉搜索树的函数,即节点越深,则比较的次数就越多。

但对于同一个关键码集合,如果各关键码插入的次序不同,可能得到不同结构的二叉搜索树:

最好情况下:二叉搜索树为完全二叉树,平均比较次数为logN

最坏情况下:二叉搜索树退化为单分支树,其平均比较次数为:N / 2

可以及逆行改进,使得不管按照什么次序插入关键码,都可以使得二叉搜索树的性能最佳 -- 数据结构高阶时候学习!

2. 搜索

2.1 概念及场景

Map和Set是一种专门用来进行搜索的容器或者数据结构,其搜索的效率与其具体的实例化子类有关。之前常见的搜索方式有:

  1. 直接遍历:时间复杂度为O(N),元素如果比较多的话,效率较低。
  2. 二分查找:时间复杂度为O(logN),但搜索前必须要求序列是有序的

上述方式比较适合静态类型的数据进行查找,即一般不会对区间内进行插入和删除操作了,但在现实情况中的查找:1. 根据姓名查询考试成绩 2. 通讯录,即根据姓名查询联系方式 3. 不重复集合,即需要先搜索关键字是否已经在集合中,可能在查找的过程中进行一些插入和删除的操作,即动态查找,那上述两种方式就不合适了,这里介绍的Map和Set是一种适合动态查找的集合容器

2.2 模型

一般把搜索的数据称为关键字(Key),和关键字对应的称为值(Value),将其称之为Key-value的键值对,所以模型有两种:

  1. 纯Key模型,比如 有一个英文词典,快速查找一个单词是否收录在该词典中
  2. Key-Value模型,比如,梁山好汉的绰号

Map中存储的就是key-value键值对,Set中只存储了Key

3. Map的使用

Map官方文档:Map (Java Platform SE 8 )


3.1 Map的说明:

Map是一个接口类,并没有继承自Collection,该类中存储的是<K,V>结构的键值对,并且K一定是唯一的,不能重复

3.2 关于Map.Entry<K,V>的说明

Map.Entr<K,V>是Map内部实现的用来存放<key,value>键值对映射关系的内部类,该内部类中主要提供了key和value的获取,value的设置以及key的比较方式

注意:Map.Entry<K,V>并没有提供设置Key的方法

3.3 Map的常用方法说明

注意:

  1. Map是一个接口,不能直接实例化对象,如果要实例化对象是能实例化其实现类TreeMap或者HashMap
  2. Map中存放键值对的Key是唯一的value是可以重复的
  3. 在TreeMap中插入键值对时,key不能为空,否则会抛出空指针异常,但value可以为空,在HashMap中,key和value都可以为空
  4. Map中的Key可以全部分离出来,存储到Set中来进行访问(因为Key不能重复)
  5. Map中的value可以全部分离出来,存储在Collection的任何一个子集中(value可能有重复)。
  6. Map中键值对的Key不能直接修改,value可以修改,如果要修改key,只能先将该key删除掉,然后再来进行重新插入。

3.4 TreeMap的使用案例

getOrDefault方法的源码:

完!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/70991.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯 路径之谜

路径之谜 题目描述 小明冒充 XX 星球的骑士&#xff0c;进入了一个奇怪的城堡。 城堡里边什么都没有&#xff0c;只有方形石头铺成的地面。 假设城堡地面是 nnnn 个方格。如下图所示。 按习俗&#xff0c;骑士要从西北角走到东南角。可以横向或纵向移动&#xff0c;但不能斜着走…

langchain4j+local-ai小试牛刀

序 本文主要研究一下如何本地运行local-ai并通过langchain4j集成调用。 步骤 curl安装 curl https://localai.io/install.sh | sh% Total % Received % Xferd Average Speed Time Time Time CurrentDload Upload Total Spent Left Speed 100 21509 …

Milvus高性能向量数据库与大模型结合

Milvus | 高性能向量数据库&#xff0c;为规模而构建Milvus 是一个为 GenAI 应用构建的开源向量数据库。使用 pip 安装&#xff0c;执行高速搜索&#xff0c;并扩展到数十亿个向量。https://milvus.io/zh Milvus 是什么&#xff1f; Milvus 是一种高性能、高扩展性的向量数据…

kettle插件-自定义函数-数据脱敏

平常我们在使用kettle抽取数据的时候会涉及到敏感数据邀请脱敏或者进行掩码的需求&#xff0c;今天我们使用自定义函数插件来实现这些需求。 1、将自定义函数插件&#xff08;kettle-func-plugin.zip&#xff09;解压后放到kettle的plugins目录下面&#xff0c;然后重启服务。…

探秘《矩阵之美》:解锁矩阵的无限魅力

在这个数据驱动的时代&#xff0c;矩阵作为数学中的瑰宝&#xff0c;不仅在理论研究中占据核心地位&#xff0c;更在工程技术、计算机科学、物理学、经济学等众多领域发挥着不可替代的作用。今天&#xff0c;让我们通过中科院大学耿修瑞老师&#xff08;中科院空天信息研究院研…

【MySQL】(2) 库的操作

SQL 关键字&#xff0c;大小写不敏感。 一、查询数据库 show databases; 注意加分号&#xff0c;才算一句结束。 二、创建数据库 {} 表示必选项&#xff0c;[] 表示可选项&#xff0c;| 表示任选其一。 示例&#xff1a;建议加上 if not exists 选项。 三、字符集编码和排序…

Vue3实现文件上传、下载及预览全流程详解(含完整接口调用)

文章目录 一、环境准备1.1 创建Vue3项目1.2 安装依赖1.3 配置Element Plus 二、文件上传实现2.1 基础上传组件2.2 自定义上传逻辑&#xff08;Axios实现&#xff09; 三、文件下载实现3.1 直接下载&#xff08;已知文件URL&#xff09;3.2 后端接口下载&#xff08;二进制流&am…

免费使用 DeepSeek API 教程及资源汇总

免费使用 DeepSeek API 教程及资源汇总 一、DeepSeek API 资源汇总1.1 火山引擎1.2 百度千帆1.3 阿里百炼1.4 腾讯云 二、其他平台2.1 华为云2.2 硅基流动 三、总结 DeepSeek-R1 作为 2025 年初发布的推理大模型&#xff0c;凭借其卓越的逻辑推理能力和成本优势&#xff0c;迅速…

千峰React:案例二

完成对html文档还有css的引入&#xff0c;引入一下数据&#xff1a; import { func } from prop-types import ./购物车样式.css import axios from axios import { useImmer } from use-immer import { useEffect } from reactfunction Item() {return (<li classNameacti…

redis的下载和安装详解

一、下载redis安装包 进入redis官网查看当前稳定版本&#xff1a; https://redis.io/download/发现此时的稳定版本是6.2.4&#xff0c; 此时可以去这个网站下载6.2.4稳定版本的tar包。 暂时不考虑不在windows上使用redis&#xff0c;那样将无法发挥redis的性能 二、上传tar…

Python基于Django的网络课程在线学习平台【附源码】

博主介绍&#xff1a;✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&…

第四届大数据、区块链与经济管理国际学术会议

重要信息 官网&#xff1a;www.icbbem.com 时间&#xff1a;2025年3月14-16日 地点&#xff1a;中国-武汉 &#xff08;线上召开&#xff09; 简介 第四届大数据、区块链与经济管理国际学术会议(ICBBEM 2025)&#xff0c;将于2025年3月14-16日在中国湖北省武汉市召开。…

使用Docker Compose部署 MySQL8

MySQL 8 是一个功能强大的关系型数据库管理系统,而 Docker 则是一个流行的容器化平台。结合使用它们可以极大地简化 MySQL 8 的部署过程,并且确保开发环境和生产环境的一致性。 安装 Docker 和 Docker Compose 首先,确保你的机器上已经安装了 Docker 和 Docker Compose。 …

mamba_ssm和causal-conv1d详细安装教程

1.前言 Mamba是近年来在深度学习领域出现的一种新型结构&#xff0c;特别是在处理长序列数据方面表现优异。在本文中&#xff0c;我将介绍如何在 Linux 系统上安装并配置 mamba_ssm 虚拟环境。由于官方指定mamba_ssm适用于 PyTorch 版本高于 1.12 且 CUDA 版本大于 11.6 的环境…

利用 Python 爬虫进行跨境电商数据采集

1 引言2 代理IP的优势3 获取代理IP账号4 爬取实战案例---&#xff08;某电商网站爬取&#xff09;4.1 网站分析4.2 编写代码4.3 优化代码 5 总结 1 引言 在数字化时代&#xff0c;数据作为核心资源蕴含重要价值&#xff0c;网络爬虫成为企业洞察市场趋势、学术研究探索未知领域…

HONOR荣耀MagicBook 15 2021款 独显(BOD-WXX9,BDR-WFH9HN)原厂Win10系统

适用型号&#xff1a;【BOD-WXX9】 MagicBook 15 2021款 i7 独显 MX450 16GB512GB (BDR-WFE9HN) MagicBook 15 2021款 i5 独显 MX450 16GB512GB (BDR-WFH9HN) MagicBook 15 2021款 i5 集显 16GB512GB (BDR-WFH9HN) 链接&#xff1a;https://pan.baidu.com/s/1S6L57ADS18fnJZ1…

c语言实现三子棋小游戏(涉及二维数组、函数、循环、常量、动态取地址等知识点)

使用C语言实现一个三子棋小游戏 涉及知识点&#xff1a;二维数组、自定义函数、自带函数库、循环、常量、动态取地址等等 一些细节点&#xff1a; 1、引入自定义头文件&#xff0c;需要用""双引号包裹文件名&#xff0c;目的是为了和官方头文件的<>区分开。…

Web自动化之Selenium添加网站Cookies实现免登录

在使用Selenium进行Web自动化时&#xff0c;添加网站Cookies是实现免登录的一种高效方法。通过模拟浏览器行为&#xff0c;我们可以将已登录状态的Cookies存储起来&#xff0c;并在下次自动化测试或爬虫任务中直接加载这些Cookies&#xff0c;从而跳过登录步骤。 Cookies简介 …

NAT 技术:网络中的 “地址魔术师”

目录 一、性能瓶颈&#xff1a;NAT 的 “阿喀琉斯之踵” &#xff08;一&#xff09;数据包处理延迟 &#xff08;二&#xff09;高并发下的性能损耗 二、应用兼容性&#xff1a;NAT 带来的 “适配难题” &#xff08;一&#xff09;端到端通信的困境 &#xff08;二&…

php序列化与反序列化

文章目录 基础知识魔术方法&#xff1a;在序列化和反序列化过程中自动调用的方法什么是 __destruct() 方法&#xff1f;何时触发 __destruct() 方法&#xff1f;用途&#xff1a;语法示例&#xff1a; 反序列化漏洞利用前提条件一些绕过策略绕过__wakeup函数绕过正则匹配绕过相…