做类似淘宝网站怎么做专业3合1网站建设电话

news/2025/9/27 15:15:59/文章来源:
做类似淘宝网站怎么做,专业3合1网站建设电话,惠州市seo广告优化营销工具,网站建设调研提纲前段时间#xff0c;小灰发布了红黑树相关的文章#xff0c;分成上下篇来讲解。这一次#xff0c;小灰把两篇文章做了整合#xff0c;并且修正了红黑树删除部分的图片错误#xff0c;感谢大家的指正。————— 第二天 —————————————————二叉查找树小灰发布了红黑树相关的文章分成上下篇来讲解。这一次小灰把两篇文章做了整合并且修正了红黑树删除部分的图片错误感谢大家的指正。—————  第二天  —————————————————二叉查找树BST具备什么特性呢1.左子树上所有结点的值均小于或等于它的根结点的值。2.右子树上所有结点的值均大于或等于它的根结点的值。3.左、右子树也分别为二叉排序树。下图中这棵树就是一颗典型的二叉查找树1.查看根结点92.根据二叉查找树左子树小、右子树大的特性10 9因此值为10的结点只可能在根结点的右子树当中我们查看右孩子结点133.由于10 13因此查看左孩子114.由于10 11因此查看左孩子10发现10正是要查找的结点假设初始的二叉查找树只有三个结点根结点值为9左孩子值为8右孩子值为12接下来我们依次插入如下五个结点7,6,5,4,3。依照二叉查找树的特性结果会变成什么样呢1.结点是红色或黑色。2.根结点是黑色。3.每个叶子结点都是黑色的空结点NIL结点。4 每个红色结点的两个子结点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色结点)5.从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。下图中这棵树就是一颗典型的红黑树什么情况下会破坏红黑树的规则什么情况下不会破坏规则呢我们举两个简单的例子1.向原红黑树插入值为14的新结点由于父结点15是黑色结点因此这种情况并不会破坏红黑树的规则无需做任何调整。2.向原红黑树插入值为21的新结点由于父结点22是红色结点因此这种情况打破了红黑树的规则4每个红色结点的两个子结点都是黑色必须进行调整使之重新符合红黑树的规则。变色为了重新符合红黑树的规则尝试把红色结点变为黑色或者把黑色结点变为红色。下图所表示的是红黑树的一部分子树新插入的结点Y是红色结点它的父亲结点X也是红色的不符合规则4因此我们可以把结点X从红色变成黑色但是仅仅把一个结点变色会导致相关路径凭空多出一个黑色结点这样就打破了规则5。因此我们需要对其他结点做进一步的调整后文会详细说明。左旋转逆时针旋转红黑树的两个结点使得父结点被自己的右孩子取代而自己成为自己的左孩子。说起来很怪异大家看下图图中身为右孩子的Y取代了X的位置而X变成了自己的左孩子。此为左旋转。右旋转顺时针旋转红黑树的两个结点使得父结点被自己的左孩子取代而自己成为自己的右孩子。大家看下图图中身为左孩子的Y取代了X的位置而X变成了自己的右孩子。此为右旋转。局面1新结点A位于树根没有父结点。(空心三角形代表结点下面的子树)这种局面直接让新结点变色为黑色规则2得到满足。同时黑色的根结点使得每条路径上的黑色结点数目都增加了1所以并没有打破规则5。局面2新结点B的父结点是黑色。这种局面新插入的红色结点B并没有打破红黑树的规则所以不需要做任何调整。局面3新结点D的父结点和叔叔结点都是红色。这种局面两个红色结点B和D连续违反了规则4。因此我们先让结点B变为黑色这样一来结点B所在路径凭空多了一个黑色结点打破了规则5。因此我们让结点A变为红色这时候结点A和C又成为了连续的红色结点我们再让结点C变为黑色经过上面的调整这一局部重新符合了红黑树的规则。局面4新结点D的父结点是红色叔叔结点是黑色或者没有叔叔且新结点是父结点的右孩子父结点B是祖父结点的左孩子。我们以结点B为轴做一次左旋转使得新结点D成为父结点原来的父结点B成为D的左孩子这样一来进入了局面5。局面5新结点D的父结点是红色叔叔结点是黑色或者没有叔叔且新结点是父结点的左孩子父结点B是祖父结点的左孩子。我们以结点A为轴做一次右旋转使得结点B成为祖父结点结点A成为结点B的右孩子接下来我们让结点B变为黑色结点A变为红色经过上面的调整这一局部重新符合了红黑树的规则。以上就是红黑树插入操作所涉及的5种局面。或许有人会问如果局面4和局面5当中的父结点B是祖父结点A的右孩子该怎么办呢很简单如果局面4中的父结点B是右孩子则成为了局面5的镜像原本的右旋操作改为左旋如果局面5中的父结点B是右孩子则成为了局面4的镜像原本的左旋操作改为右旋。给定下面这颗红黑树新插入的结点是21显然新结点21和它的父结点22是连续的红色结点违背了规则4我们应该如何调整呢让我们回顾一下刚才讲的5种局面当前的情况符合局面3“新结点的父结点和叔叔结点都是红色。”于是我们经过三次变色22变为黑色25变为红色27变为黑色经过上面的调整以结点25为根的子树符合了红黑树规则但结点25和结点17成为了连续的红色结点违背规则4。于是我们把结点25看做一个新结点正好符合局面5的镜像“新结点的父结点是红色叔叔结点是黑色或者没有叔叔且新结点是父结点的右孩子父结点是祖父结点的右孩子”于是我们以根结点13为轴进行左旋转使得结点17成为了新的根结点接下来让结点17变为黑色结点13变为红色如此一来我们的红黑树变得重新符合规则。二叉查找树是如何进行删除操作的呢可以分成三种情况。情况1待删除的结点没有子结点上图中待删除的结点12是叶子结点没有孩子因此直接删除即可情况2待删除的结点有一个孩子上图中待删除的结点13只有左孩子于是我们让左孩子结点11取代被删除的结点结点11以下的结点关系无需变动情况3待删除的结点有两个孩子上图中待删除的结点5有两个孩子这种情况比较复杂。此时我们需要选择与待删除结点最接近的结点来取代它。上面的例子中结点3仅小于结点5结点6仅大于结点5两者都是合适的选择。但习惯上我们选择仅大于待删除结点的结点也就是结点6来取代它。于是我们复制结点6到原来结点5的位置被选中的结点6仅大于结点5因此一定没有左孩子。所以我们按照情况1或情况2的方式删除多余的结点6:红黑树的特性规则如下1.结点是红色或黑色。2.根结点是黑色。3.每个叶子结点都是黑色的空结点NIL结点。4.每个红色结点的两个子结点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色结点)5.从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。下面我们通过一个例子来看一看删除红黑树的结点会对规则产生怎样的影响上图的这颗红黑树待删除的是黑色结点1有一个右孩子。根据二叉查找树的删除流程我们让右孩子结点6直接取代结点1显然这颗新的二叉树打破了两个规则规则4. 每个红色结点的两个子结点都是黑色。规则5. 从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。第一步如果待删除结点有两个非空的孩子结点转化成待删除结点只有一个孩子或没有孩子的情况。上面例子是一颗红黑树的局部标数字的三角形代表任意形态的子树假设结点8是待删除结点。根据上文讲解的二叉查找树删除流程由于结点8有两个孩子我们选择仅大于8的结点10复制到8的位置结点颜色变成待删除结点的颜色接下来我们需要删除红色的结点10红色结点10能成为仅大于8的结点必定没有左孩子结点所以问题转换成了待删除结点只有一个右孩子或没有孩子的情况。接下来我们进入第二步。第二步根据待删除结点和其唯一子结点的颜色分情况处理。情况1自身是红色子结点是黑色这种情况最简单按照二叉查找树的删除操作删除结点1即可情况2自身是黑色子结点是红色这种情况也很简单首先按照二叉查找树的删除操作删除结点1此时这条路径凭空减少了一个黑色结点那么我们把结点2变成黑色即可情况3自身是黑色子结点也是黑色或者子结点是空叶子结点这种情况最复杂涉及到很多变化。首先我们还是按照二叉查找树的删除操作删除结点1显然这条路径上减少了一个黑色结点而且结点2再怎么变色也解决不了。这时候我们进入第三步专门解决父子双黑的情况。第三步遇到双黑结点在子结点顶替父结点之后分成6种子情况处理。子情况1结点2是红黑树的根结点此时所有路径都减少了一个黑色结点并未打破规则不需要调整。子情况2结点2的父亲、兄弟、侄子结点都是黑色此时我们直接把结点2的兄弟结点B改为红色这样一来原本结点2所在的路径少了一个黑色结点现在结点B所在的路径也少了一个黑色结点两边“扯平”了。可是结点A以下的每一条路径都减少了一个黑色结点与结点A之外的其他路径又造成了新的不平衡啊没关系我们让结点A扮演原先结点2的角色进行递归操作重新判断各种情况。子情况3结点2的兄弟结点是红色首先以结点2的父结点A为轴进行左旋然后结点A变成红色、结点B变成黑色这样的意义是什么呢结点2所在的路径仍然少一个黑色结点呀别急这样的变化有可能转换成子情况4、5、6中的任意一种在子情况4、5、6当中会进一步解决。子情况4结点2的父结点是红色兄弟和侄子结点是黑色这种情况我们直接让结点2的父结点A变成黑色兄弟结点B变成红色这样一来结点2的路径补充了黑色结点而结点B的路径并没有减少黑色结点重新符合了红黑树的规则。子情况5结点2的父结点随意兄弟结点B是黑色右孩子左侄子结点是红色右侄子结点是黑色这种情况下首先以结点2的兄弟结点B为轴进行右旋接下来结点B变为红色结点C变为黑色这样的变化转换成了子情况6。子情况6结点2的父结点随意兄弟结点B是黑色右孩子右侄子结点是红色首先以结点2的父结点A为轴左旋接下来让结点A和结点B的颜色交换并且结点D变为黑色这样是否解决了问题呢经过结点2的路径由随意黑变成了随意黑黑补充了一个黑色结点经过结点D的路径由随意黑红变成了随意黑黑色结点并没有减少。所以这时候重新符合了红黑树的规则。以上就是红黑树删除的全过程。给定下面这颗红黑树待删除的是结点17第一步由于结点17有两个孩子子树当中仅大于17的结点是25所以把结点25复制到17位置保持黑色接下来我们需要删除原本的结点25这个情况正好对应于第二步的情况三即待删除结点是黑色子结点是空叶子结点。于是我们删除框框中结点25进入第三步此时框框中的结点虽然是空叶子结点但仍然可以用于判断局面当前局面符合子情况5的镜像于是我们通过左旋和变色把子树转换成情况6的镜像再经过右旋、变色子树最终成为了下面的样子这样一来整颗二叉树又重新符合了红黑树的规则。 往期推荐万字详解|手撕 9大排序算法2020-09-11 URL 去重的 6 种方案(附详细代码)2020-09-09 字符串操作的12个小技巧2020-09-10 关注下方二维码收获更多干货

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

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

相关文章

消息队列Apache Kafka教程 - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

长春专业网站建设公司排名2345官方网站

jQuery模态框弹窗提示代码 下载地址 jQuery模态框弹窗提示代码

9.21~9.27 周总结

分类 dp 当状态分为几类,而且降维时每一类要降的维不一样,我们可以对每一类分别开 dp,用不同的状态设计达到优化目的。 CF2143D2 Inversion Graph Coloring (Hard Version) - 洛谷 构造交换器 在序列转换问题(即给…

大中午记梦

应该是我第一次写记梦 果然唐人到了哪都是最唐的,无论是在梦里/jk (做梦内容与现实相关,此时现实中已经下午两点多了,并且机房外响起了装修声) 以下为梦境: 不知道在什么地方,但应该不是机房,应该不是厕所,也…

浙江省城乡建设厅网站网址申请域名

目录 一、所有主机初始化 二、135、136服务器,部署DNS调度服务器 1、更改主机主从DNS服务器的主机名称 2、安装bind软件、修改主配置文件 3、修改区域配置文件 4、修改数据文件 5、启动named服务、修改网卡信息 6、解析 7、双网卡的话记得注释以下内容、注…

网站建设这个职业备案网站首页地址

目录 依赖安装 下载编译libgeos 下载编译proj4 编译Postgresql9 编译PostGIS2 启动postgresql服务 开通外部网络访问 数据库开启PostGIS扩展 查看PostGIS版本 升级PostGIS版本 依赖安装 这个命令里面安装的包可能会多,由于是编译GreenPlum用的&#xff0…

软件项目网站建设实验报告专门做财经的网站

odoo16默认情况下每周都会发送一个“系统各功能状态日报”的邮件,而且是所有人都发, 这个功能在哪配置呢? 今天研究了一下, 线索是“系统各功能状态日报”,先全文检索吧 #. module: digest #: model:digest.digest,na…

计算机毕业设计springboot我国制氢产业专利检索系统的设计与实现 基于Spring Boot框架的中国制氢产业专利检索平台开发与设计 Spring Boot手艺驱动的中国制氢产业专利检索系统构建

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

9.21~9.27

分类 dp 当状态分为几类,而且降维时每一类要降的维不一样,我们可以对每一类分别开 dp,用不同的状态设计达到优化目的。 CF2143D2 Inversion Graph Coloring (Hard Version) - 洛谷 构造交换器 在序列转换问题(即给…

Jetbrains 全家桶激活码激活

本文介绍了JetBrains系列软件的激活方法:首先访问指定网站,选择可用链接下载压缩包并解压;运行install脚本后,从网站复制对应软件的激活码;最后在目标软件中粘贴激活码完成激活。已激活过JetBrains软件的用户只需…

Arbess从入门到实战(3) - 启用Arbess+GitLab实现Vue.js计划自动化部署

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

机关网站建设需求文档涪陵网站制作

文章目录 【Unity】终极移动指南-注解(从移动、抓钩到贪吃蛇)观前提醒链接地址: 内容一、 transform移动操作【1】transform.position变换位置【2】transform.Translate平移【3】transform.position 类似平移的操作【4】定向矢量【5】停在指定…

网站服务器内网打不开网页网站建设开场白

目录 一、创建项目二、first demo1、application.properties2、ChatController3、结果 三、个人思考 一、创建项目 官方文档的Getting Started 最低要求:JDK17 阿里云的Server URL(https://start.aliyun.com/)搜不到Spring AI,…

【深度学习计算机视觉】07:单发多框检测(SSD) - 指南

【深度学习计算机视觉】07:单发多框检测(SSD) - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas&…

MZOI 2025.9.27

省流:改四个字符过一个题。 开题,T1 秒乐,T2 看上去码量巨大,T3T4 没思路。 开写,半个小时写完 T1,过了所有大样例。 开 T2,写写写,写写写,写写写,一个半小时写完过了所有大样例。 还剩两个半小时,优势在我…

Spring Framework 远程命令执行漏洞

Spring Framework简单介绍 Spring Frame为现代企业应用程序提供了一个全面和可配置的编程模型,开发者可以根据需要快速选择需要的模块。使用spring来管理应用程序,可以将开发者从基础框架中解脱出来,专注于业务逻辑…

配置本地环境以管理Git多账户SSH连接

生成SSH密钥打开终端。为第一个账户生成一个新的SSH密钥: ssh-keygen -t rsa -b 4096 -C "your_email@example.com" 当提示你输入文件名时,指定一个独特名称,例如 id_rsa_account1。对于第二个(和随后每…

Pod、 PVC 、PV的刪除順序

先删除 Pod 再删除 PVC 最后删除 PV简单口诀:Pod -> PVC -> PV 为什么是这个顺序?深入理解删除机制 要理解这个顺序,你需要明白 Kubernetes 中这些资源之间的保护和依赖关系,尤其是 StorageClass 的 reclaim…

python基本脚本要素

python基本脚本要素2025-09-27 14:46 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-fa…