第九章 常见的二叉树:平衡二叉树之红黑树

  • 1 背景
  • 2 定义
  • 3 红黑树与AVL树对比
  • 4 树结构调整
  • 5 代码实现
    • 5.1 红黑树的插入
    • 5.2 红黑树的删除
    • 5.3 具体代码实现

1 背景

对于二叉排序树,时间复杂度最差时候会是 O(n),比如插入的元素是有序的,生成的二叉排序树就是一个链表,这种情况下,需要遍历全部元素才行。为了改变排序二叉树存在的不足,Rudolf Bayer 在 1972 年发明了另一种改进后的排序二叉树:红黑树,他将这种排序二叉树称为“对称二叉 B 树”,而红黑树这个名字则由 Leo J. Guibas 和 Robert Sedgewick 于 1978 年首次提出。

2 定义

红黑树是一种近似平衡的二叉查找树,它能够确保任何一个节点的左右子树的高度差不会超过二者中较低那个的两倍,红黑树的时间复杂为O(log(N))。具体来说,红黑树是满足如下性质的二叉查找树(binary search tree):
(1)每个结点要么是红的要么是黑的。
(2)根结点是黑的。
(3)每个叶结点(叶结点即指树尾端NIL指针或NULL结点,和我们说的叶子节点不是一样的)都是黑的。
(4)如果一个结点是红的,那么它的两个儿子都是黑的。
(5)对于任意结点而言,其到叶结点树尾端NIL指针(叶子节点的孩子)的每条路径都包含相同数目的黑结点。

注:
黑色高度:从根节点到叶节点的路径上黑色节点的个数,叫做树的黑色高度

3 红黑树与AVL树对比

(1)AVL树的时间复杂度虽然优于红黑树,但是对于现在的计算机,cpu太快,可以忽略性能差异
(2)红黑树的插入删除比AVL树更便于控制操作
(3)红黑树整体性能略优于AVL树,因为红黑树旋转情况少于AVL树

4 树结构调整

在树的结构发生改变时(插入或者删除操作),往往会破坏上述5个条件中的条件4或条件5,需要通过调整使得查找树重新满足红黑树的条件。调整可以分为两类:一类是颜色调整,即改变某个节点的颜色;另一类是结构调整,集改变检索树的结构关系。结构调整过程包含两个基本操作:左旋(Rotate Left),右旋(RotateRight),左右旋在前面的课程已讲解。
(1)Y右旋
父亲y变成左子x的右子,左子x的右子B变成y左子B
(2)X左旋
父亲x变成右子y的左子,右子y的左子B变成x的右子B

在这里插入图片描述

5 代码实现

在 Java 集合框架中,很多部分(HashMap, TreeMap, TreeSet 等)都有红黑树的应用,这些集合均提供了很好的性能。

5.1 红黑树的插入

(1)调整思想
首先要知道红黑树是基于排序二叉树或者说二叉查找树进行插入的,,红黑树的第 5 条特征规定,任一节点到它子树的每个叶子节点的路径中都包含同样数量的黑节点。也就是说当我们往红黑树中插入一个黑色节点时,会违背这条特征。同时第 4 条特征规定红色节点的左右孩子一定都是黑色节点,当我们给一个红色节点下插入一个红色节点时,会违背这条特征。前面说了,插入一个节点后要担心违反特征 4 和 5,数学里最常用的一个解题技巧就是把多个未知数化解成一个未知数。我们这里采用同样的技巧,把插入的节点直接染成红色,这样就不会影响特征 5,只要专心调整满足特征 4 就好了。这样比同时满足 4、5 要简单一些。染成红色后,我们只要关心父节点是否为红,如果是红的,就要把父节点进行变化,让父节点变成黑色,或者换一个黑色节点当父亲,这些操作的同时不能影响 不同路径上的黑色节点数一致的规则。

(2)插入步骤
1)基于二叉查找树插入
2)插入后结构调整
【1】父亲节点和叔叔节点都是红色
假设插入的是节点 X,这时父亲节点 A 和叔叔节点B 都是红色,爷爷节点 C 一定是黑色。
红色节点的孩子不能是红色,这时不管 X 是 A 的左孩子还是右孩子,只要同时把 A 和 B 染成黑色,C 染成红色即可。这样这个子树左右两边黑色个数一致,也满足特征 4。
但是这样改变后C 染成红色,C的父亲如果是红色岂不是又违反特征 4。因此需要以 爷爷节点 C 为新的调整节点,再次进行调整操作,以此循环,直到父亲节点不是红的,就没有问题了。
在这里插入图片描述

【2】父亲节点为红色,叔叔节点为黑色
1】当前节点是父亲的左孩子,当前节点=X
假设插入的是节点 X,这时父亲节点 A 是红色,叔叔节点 B 是黑色,爷爷节点 C 一定是黑色。红色节点的孩子不能是红色,但是直接把父亲节点 A 涂成黑色也不行,这条路径多了个黑色节点。可以通过右旋C,这时候右子树多了一个黑色,把C染红,然后父亲节点染黑就可以

在这里插入图片描述

2】当前节点是父亲的右孩子,一开始当前节点=X,后来当前节点=A
先以当前节点X的父节点A为支点进行左旋,然后就转换成1)中的场景了,然后以A作为当前节点进行1)的步骤就行了

在这里插入图片描述

5.2 红黑树的删除

(1)调整思想
根据红黑树的第 5 个特性:如果当前待删除节点是红色的,它被删除之后对当前树的特性不会造成任何破坏影响。而如果被删除的节点是黑色的,这就需要进行进一步的调整来保证后续的树结构满足要求。这里研究的是删除黑色节点的情况。为了保证删除节点父亲节点左右两边黑色节点数一致,需要重点关注父亲节点没删除的那一边节点是不是黑色。如果删除后父亲节点另一边比删除的一边黑色节点多,就要想办法搞到平衡,具体的平衡方法有如下几种方法:把父亲节点另一边(即删除节点的兄弟树)其中一个节点弄成红色,也少一个黑色;或者把另一边多的黑色节点旋转过来一个

(2)删除步骤
1)基于二叉查找树的删除
2)删除后结构调整
只考虑删除的是黑色节点
【1】兄弟如果是红的,当前节点=X
说明兄台的孩子都是黑的,其实把兄弟转成黑的是为了转化成2中的场景
1】把兄弟搞成黑的
2】父亲搞成红的
3】左旋转父亲(结果兄弟给当前节点分一个黑孩子)
4】接下来对比旋转后的兄弟

在这里插入图片描述

【2】兄弟节点如果是黑色的,兄弟的孩子就具有不确定性了,接上【1】,此时兄弟是E,假如有两孩子是F和G,并且都是黑色的
1】 兄弟的孩子都是黑色的
A. 把兄弟染成红的即可,那么子树就算调整完了
B. 以父节点为当前节点,继续往上调整父级节点
刚好这里X的父亲节点是红色的,那么直接把父亲节点染黑即可,不会影响到性质5

在这里插入图片描述

2】 兄弟节点的孩子最多只有1个黑色的时候,接上【1】,此时兄弟是E,假如E有两孩子F和G,有一孩子,假如G是黑色的
《1》兄弟有个孩子是黑色的
这个步骤是为了转换成兄弟的孩子没有黑色的情况,即都是红色的
A.把不是黑的那个孩子搞黑
B.兄弟搞红
C.兄弟右旋转
D.以后对比旋转后的兄弟

在这里插入图片描述

《2》兄弟的孩子都是红色的,接上《1》,假如F还有个孩子是红色的H,当然没有也没关系,兄弟的孩子只要没有黑色的都是要走这个步骤
A.把兄弟涂成跟父亲一样的颜色
B.然后把父亲搞黑
C.把兄弟的右孩子搞黑
D.父亲节点左旋
E.刚好X的父亲C不是根节点,并C是黑色的,所以继续以C作为当前节点研究上一级
在这里插入图片描述

【3】只要当前节点的父亲是黑色的并且当前节点还不是根节点,
就要继续步骤【1】和【2】,否则当前节点要么是红色节点或者是根,那就染黑然后结束

5.3 具体代码实现

public class RedBlackTree{private class Node{public E e;public int color;public Node parent;public Node(E e){this.e = e;this.color = 0;this.parent = null;}}private Node root;public RedBlackTree(){root=null;}	/*** 插入* @param node * @return*/	public void insert(Node node){//这个是二叉搜索树的插入算法,前面讲过了,这里不讲了insertBinarySearchTree(node);//插入后的结构调整fixAfterInsertion(node);}/*** 插入后的结构调整* @param x 节点集合* @return*/	private void fixAfterInsertion(Node x) {//直接染成红色,降低问题的复杂性x.color = RED;  //当前不是根几点,并且父亲节点是红色的,才需要调整while (x != null && x != root && x.parent.color == RED) {// 插入节点 x 的父亲节点位于左孩子if (parentOf(x) == leftOf(parentOf(parentOf(x)))) {   //叔叔节点		Node y = rightOf(parentOf(parentOf(x)));  //如果叔叔是红色if (colorOf(y) == RED) {    setColor(parentOf(x), BLACK);setColor(y, BLACK);setColor(parentOf(parentOf(x)), RED);x = parentOf(parentOf(x));} //如果叔叔是黑色else {    //当前节点是父亲的右孩子,要多做一次左旋   if (x == rightOf(parentOf(x))) {x = parentOf(x);rotateLeft(x);}setColor(parentOf(x), BLACK);setColor(parentOf(parentOf(x)), RED);rotateRight(parentOf(parentOf(x)));}} //和上面对称,原理一样else {     Node y = leftOf(parentOf(parentOf(x)));if (colorOf(y) == RED) {setColor(parentOf(x), BLACK);setColor(y, BLACK);setColor(parentOf(parentOf(x)), RED);x = parentOf(parentOf(x));} else {if (x == leftOf(parentOf(x))) {x = parentOf(x);rotateRight(x);}setColor(parentOf(x), BLACK);setColor(parentOf(parentOf(x)), RED);rotateLeft(parentOf(parentOf(x)));}}}root.color = BLACK;}/*** 从二分搜索树中删除元素* @param e* @return*/public void delete(Node node){//这个是二叉搜索树的删除算法,前面讲过了,这里不讲了Node x = deleteBinarySearchTree(node);//删除后的结构调整fixAfterDeletion(x);}	/*** 删除后的结构调整* @param x 节点集合* @return*/		private void fixAfterDeletion(Node x) {//当前节点不是根节点,并且是黑节点,要继续调整while (x != root && colorOf(x) == BLACK) {//当前节点是左孩子if (x == leftOf(parentOf(x))) {//兄弟节点Node sib = rightOf(parentOf(x));//兄弟是红色,转化成兄弟是黑色的场景if (colorOf(sib) == RED) {setColor(sib, BLACK);setColor(parentOf(x), RED);rotateLeft(parentOf(x));sib = rightOf(parentOf(x));}/*兄弟是黑色的场景*///兄弟两孩子都是黑色的if (colorOf(leftOf(sib))  == BLACK &&colorOf(rightOf(sib)) == BLACK) {setColor(sib, RED);x = parentOf(x);} //兄弟最多有一个孩子是黑色else {//兄弟有一个孩子是黑色的,转化成兄弟没有孩子是黑色的场景if (colorOf(rightOf(sib)) == BLACK) {setColor(leftOf(sib), BLACK);setColor(sib, RED);rotateRight(sib);sib = rightOf(parentOf(x));}/*兄弟没有一个孩子是黑色的都要做下面几个步骤*/setColor(sib, colorOf(parentOf(x)));setColor(parentOf(x), BLACK);setColor(rightOf(sib), BLACK);rotateLeft(parentOf(x));x = root;}} //当前节点是右孩子,原理和左孩子一样,对称操作else { Node sib = leftOf(parentOf(x));if (colorOf(sib) == RED) {setColor(sib, BLACK);setColor(parentOf(x), RED);rotateRight(parentOf(x));sib = leftOf(parentOf(x));}if (colorOf(rightOf(sib)) == BLACK &&colorOf(leftOf(sib)) == BLACK) {setColor(sib, RED);x = parentOf(x);} else {if (colorOf(leftOf(sib)) == BLACK) {setColor(rightOf(sib), BLACK);setColor(sib, RED);rotateLeft(sib);sib = leftOf(parentOf(x));}setColor(sib, colorOf(parentOf(x)));setColor(parentOf(x), BLACK);setColor(leftOf(sib), BLACK);rotateRight(parentOf(x));x = root;}}}setColor(x, BLACK);}	}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 【Linux 性能优化系列】Linux 性能优化 -- CPU 性能篇(零) CPU 性能优化综述

    【Linux 性能优化系列】Linux 性能优化 -- CPU 性能优化综述【1】CPU 性能指标CPU 使用率 描述了非空闲时间占总 CPU 时间的百分比; 用户 CPU 使用率,包括用户态 CPU 使用率(user)和低优先级用户态 CPU 使用率(nice),表示 CPU 在用户态运行的时间百分比;用户 CPU 使用率…...

    2024/5/6 2:26:27
  2. Android 实现多种样式 item 列表

    写了几年的代码了,真心体会到了,代码得一天一天的写,饭得一天一天的吃,一口气吃个胖子的天才也不是没有,但是自己吃几碗饭,自己还是清楚的,想一想很久之前,自己写多样式列表还是直接用别人的框架,套进去了,然后出一个盼着别出 bug 的列表,最近有时间,自己撸一个简单…...

    2024/5/4 22:09:24
  3. 一起认识Spring

    Spring的AOP(一) spring中最重要的两个东西就是IOC(DI)和AOP,今天我们主要讲解有关AOP相关的知识,在了解AOP前,希望读者先了解动态代理的相关知识。 AOP我主要讲解通过注解的方式进行AOP的: 1.开启@Aspect注解,我们要让这个注解被扫描到,我们可以添加@EnableAspectJA…...

    2024/4/11 19:31:24
  4. C/C++字符串处理相关总结

    C/C++字符串处理相关总览< cctype >头文件的函数头文件内< cstring >的函数头文件< string >中的函数为什么size_t重要?ASCII字符与转义字符读入一行数据清空字符串区域复制字符串区域搜索字符串相关字符串连接字符串分割字符串比较字符串转整型/浮点型整型…...

    2024/4/23 21:48:27
  5. 玩转数据库技能自测 考试答案(阿里云打卡领T恤活动)

    下面有关PolarDB数据库集群账号说法错误的是? 选B 一个集群可以创建多个高权限账号以下哪个数据库不是关系型数据库? C.Redis7.RDS MySQL与自建数据库对比有哪些优势? 我选的ABCD。但最后是90分,怀疑这里扣分了。其他答案都很肯定。 猜测答案是BCD。A高性价比这个描述我没找…...

    2024/4/18 3:42:41
  6. Javascript基础之https工作原理是什么?

    作为一个前端,虽说每天都是在写JavaScript,但是http相关原理还是要懂的。近些年,互联网发生翻天覆地的变化。尤其是我们一直习以为常的HTTP协议,在逐渐的被HTTPS协议所取代,在浏览器、搜索引擎、CA机构、大型互联网企业的共同促进下,互联网迎来了“HTTPS加密时代”,HTTP…...

    2024/4/11 19:31:21
  7. 7寸高通八核Android9.0坚固三防平板,高亮屏户外阳光可视

    ​T75产品形态7寸安卓三防平板平台Qualcomm外观尺寸216.98*133.96*21.4mm系统Android 9.0CPUMSM8953,八核,频率2.0GhzRAM4GROM64/128GB亮度700 nit分辨率800*1280 IPS重量680g触摸屏5多点电容屏,G+G,硬度7H以上,防刮花,TP厚度:1.1mm,支持手套触摸电池3.7V/7500mAh,约7小…...

    2024/4/11 19:31:20
  8. https单向认证和双向认证demo(SpringBoot+okhttp3+keytool自签名)

    目录一、前言二、软件版本三、单向认证四、双向认证一、前言HTTPS (全称:Hyper Text Transfer Protocol over SecureSocket Layer),是以安全为目标的 HTTP 通道,在HTTP的基础上通过传输加密和身份认证保证了传输过程的安全性 [1] 。HTTPS 在HTTP 的基础下加入SSL 层,HTT…...

    2024/4/23 11:12:43
  9. Windows下Git多账号配置

    平时都是配置工作时使用的git账号,有时候需要对自己的项目进行管理,所以需要配置多个ssh_key.一、创建另一个需要管理的密钥在win10系统下打开C:\Users\Administrator文件夹,右击选择git bash here执行命令 ssh-keygen -t rsa -C roc_wl 创建对应的sshkey,命名为id_rsa_roc…...

    2024/4/10 12:05:14
  10. 数据分析——阿里资金流入流出分析(task1-数据探索与分析)

    数据分析——阿里资金流入流出分析(task1-数据探索与分析) 学习目标 熟悉数据分析的流程,了解金融时间序列分析的一般方法。 任务安排 数据集可在阿里天池下载: https://tianchi.aliyun.com/competition/entrance/231573/information 数据实践 库导入 import pandas as pd…...

    2024/4/22 6:13:52
  11. 简单的CAS单点登录

    使用Redis+cookie实现简单的单点登录1:用户第一次登陆A系统,发现未登陆,会携带上returnUrl跳转至CAS系统的登陆方法,在这个方法会验证此用户是否已经登陆(具有全局会话),如果没有登陆,就会跳转至CAS登陆页面,让用户登录@GetMapping("/login")public String …...

    2024/4/10 12:05:12
  12. 微信小程序遇到的各种小坑贴在这里

    1.image底部空白:给image组件css添加vertical-align: middle;vertical-align: middle;...

    2024/4/17 16:08:44
  13. leetcode 529. 扫雷游戏 (python)

    题目描述让我们一起来玩扫雷游戏!给定一个代表游戏板的二维字符矩阵。 M 代表一个未挖出的地雷,E 代表一个未挖出的空方块,B 代表没有相邻(上,下,左,右,和所有4个对角线)地雷的已挖出的空白方块,数字(1 到 8)表示有多少地雷与这块已挖出的方块相邻,X 则表示一个已…...

    2024/4/11 19:31:18
  14. Slf4j和Log4j的区别

    log4j 大家都知道,就不在多说了,重点说说slf4j;简单日记门面(simple logging Facade for java)SLF4J是为各种loging APIs提供一个简单统一的接口,从而使得最终用户能够在部署的时候配置自己希 望的loging APIs实现准确的说,slf4j并不是一种具体的日志系统,而是一个用户日志…...

    2024/5/5 22:10:24
  15. 通过SQL查询获取特定数据库的所有表名?

    本文翻译自:Get all table names of a particular database by SQL query? I am working on application which can deal with multiple database servers like "MySQL" and "MS SQL Server". 我正在研究可以处理多个数据库服务器(如“ MySQL”和“ MS …...

    2024/4/11 19:31:17
  16. Redis BitMap 使用场景及实现

    转载自:https://codingnote.cc/p/157727https://diuut.com/?p=1055叙述前段时间,在网上看到一道面试题:如何用redis存储统计1亿用户一年的登陆情况,并快速检索任意时间窗口内的活跃用户数量。觉得很有意思,就仔细想了下 。并做了一系列实验,自己模拟了下 。还是有点收获…...

    2024/4/11 19:31:15
  17. cef程序输出

    Cef输出输出目录中包括了CEF必选和可选的类库和资源文件(加粗的为必选),它们的主要功能如下:│ CefSharp.dll:CefSharp基础类库,定义了相关接口;│ CefSharp.Core.dll:CefSharp核心类库;│ CefSharp.WinForms.dll:CefSharp组件类库,如果是其他平台,可能是CefSharp.…...

    2024/5/5 17:18:14
  18. 【深度学习】生成对抗网络 GAN

    【深度学习】生成对抗网络 GAN引言算法简介模型介绍工作原理 引言生成式对抗网络(GAN, Generative Adversarial Networks)是一种深度学习模型,自从2014年Goodfellow提出了GAN以来,GAN已经成为近年来无监督学习最具前景的方法之一。原文链接如下: Generative Adversarial Ne…...

    2024/5/6 1:21:20
  19. RFID智能汽车制造管理系统解决方案

    RFID智能汽车制造管理系统解决方案 1.项目背景 1.1 行业背景 在汽车行业快速发展竞争日益激励的背景下,各个汽车制造商都在追求管理系统的优化。已从开始的只追求最终结果的最优,发展到目前要求使制造汽车的每个环节都达到最优的目的,这就给管理者提出了一个严峻的问题,如何…...

    2024/4/11 19:31:12
  20. VRTK插件手柄射线实例化,以及空间跳跃

    首先来实现手柄射线实例化:新建一个空物体命名为VRTK_Scripts,然后在下面新建三个空物体,分别命名为PlayArea,LeftController,RightController。然后在LeftController和RightController挂上脚本VRTK_Pointer,VRTK_StraightPointerRenderer,VRTK_ControllerEvents再然后在P…...

    2024/5/6 2:37:30

最新文章

  1. Cocos2d,一个能实现梦想的 Python 库

    大家好&#xff01;我是爱摸鱼的小鸿&#xff0c;关注我&#xff0c;收看每期的编程干货。 一个简单的库&#xff0c;也许能够开启我们的智慧之门&#xff0c; 一个普通的方法&#xff0c;也许能在危急时刻挽救我们于水深火热&#xff0c; 一个新颖的思维方式&#xff0c;也许能…...

    2024/5/6 4:45:07
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. Python读取文件里内容

    如果要读取一个文件里的内容是 # 文件名&#xff1a;db.txt 1 2 3 4代码如下 import requests f open("db.txt", mode"rb") content f.read() f.close()data content.decode(utf-8)# 存到 list 里 data_list data.split(\r\n) print(data_list)# 结果…...

    2024/5/5 8:37:34
  4. HTML——4.表格、列表、区块

    一、表格 HTML 表格是用于展示结构化数据的重要元素&#xff0c;它允许将数据以行和列的形式组织和显示。 基本结构和常见元素&#xff1a; 1. <table> 元素 <table> 元素是 HTML 表格的根元素&#xff0c;它用于定义整个表格的开始和结束。 2. <thead>、…...

    2024/5/4 16:15:43
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/5/5 18:19:03
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/5/5 12:22:20
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/5/5 19:59:54
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/5/4 23:54:44
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/5/5 15:25:47
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/5/4 23:54:49
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/5/4 23:54:44
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/5/6 1:08:53
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/5/5 18:50:00
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/5/6 0:27:44
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/5/5 2:25:33
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/5/4 21:24:42
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/5/5 13:14:22
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/5/4 13:16:06
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/5/5 17:03:52
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/5/5 21:10:50
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/5/5 3:37:58
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/5/4 23:54:30
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/5/5 17:03:21
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/5/5 15:25:31
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57