目录

1.简介

2.性质

3.泛型声明

4.树的结构

5.查找

6.插入

7.遍历

8.删除

9.示例


1.简介

二叉排序树:顾名思义它是一颗具有一定访问顺序的二叉树,通过中序遍历可以得到一个有序的序列

2.性质

一颗二叉排序树可以是空树,当它是非空树时具有以下特性:

1)当它的左子树不为空时,所有左子节点的值均小于根节点的值

2)当它的右子树不为空时,所有右子节点的值均大于根节点的值

3)它的左右子树均为二叉排序树

3.泛型声明

泛型数据需实现IComparerSearch接口,GetCompareValue()返回值用于比较计算,如下:

// -------------------------------------------------------------------------------------
// 常用搜索算法(泛型)(仅支持int比较:GetCompareValue())
// 泛型要实现IComparerSearch接口 示例如下:
//public class Data : IComparerSearch
//{
//    public int id; // 示例字段,可自定义
//
//    public int GetCompareValue()
//    {
//        return this.id;
//    }
//}
// -------------------------------------------------------------------------------------/// <summary>
/// 泛型查找需要实现此接口
/// </summary>
public interface IComparerSearch
{/// <summary>/// 获取参与排序比较的值/// </summary>int GetCompareValue();
}

4.树的结构

/// <summary>
/// 二叉树数据结构
/// </summary>
/// <typeparam name="T">实现了IComparerSearch接口的类/struct</typeparam>
public class BSTree<T> where T : IComparerSearch
{public T value;public BSTree<T> lChild;public BSTree<T> rChild;
}

二叉树数据结构包括左右子树节点,和用于存放泛型数据的value

二叉排序树的常用操作有:查找、插入、删除和遍历;如下我们逐一详解

5.查找

二叉排序树的查找返回两个参数:1.查找到的泛型数据;2.未查找到的可以插入的节点insertNode;

/// <summary>
/// 二叉排序树查找
/// </summary>
// <typeparam name="T">实现IComparerSearch的泛型数据</typeparam>
// <param name="root">二叉排序树的根节点</param>
// <param name="key">查找的值(同IComparerSearch的GetCompareValue()返回值相比较)</param>
// <param name="insertNode">未查找到的插入节点</param>
// <returns>查找到的泛型数据</returns>
public static T SearchBSTree<T>(BSTree<T> root, int key, out BSTree<T> insertNode) where T : IComparerSearch
{return SearchBSTree(root, root, key, out insertNode);
}private static T SearchBSTree<T>(BSTree<T> root, BSTree<T> node, int key, out BSTree<T> insertNode) where T : IComparerSearch
{if (root == null){insertNode = null;return default(T);}else if (node == null){// 未找到,如果有父节点则返回父节点insertNode = root;return default(T);}else if (node.value.GetCompareValue() == key){// 找到则返回当前节点insertNode = node;return node.value;}else if (node.value.GetCompareValue() > key)return SearchBSTree(node, node.lChild, key, out insertNode); // 左子树elsereturn SearchBSTree(node, node.rChild, key, out insertNode); // 右子树
}

6.插入

二叉排序树在插入时,首先会与当前节点的值做比较(根节点值为空则直接插入到根节点),等于返回(相同的值不会重复插入),小于则插入到此节点的左子树中,大于则插入到此节点的右子树中。如下图所示:依次将{ 66, 33, 77, 55, 88 } 插入到树中

如图所示,插入后生成一颗二叉排序树,当用中序遍历树时,则得到一个有序序列 :{ 33,55,66,77,88 }

代码如下:

/// <summary>
/// 二叉排序树插入(相同的value不会重复插入)
/// </summary>
// <typeparam name="T">实现IComparerSearch的泛型数据</typeparam>
// <param name="root">二叉排序树的根节点</param>
// <param name="value">插入的泛型数据</param>
public static void InsertBSTree<T>(BSTree<T> root, T value) where T : IComparerSearch
{if (root.value == null){// 第一个元素插入根节点root.value = value;}else{BSTree<T> insertNode;// 树中不存在时插入(相同的value不会重复插入)if (SearchBSTree(root, value.GetCompareValue(), out insertNode) == null && insertNode != null){if (value.GetCompareValue() < insertNode.value.GetCompareValue()){// 插入左子树insertNode.lChild = new BSTree<T>();insertNode.lChild.value = value;}else{// 插入右子树insertNode.rChild = new BSTree<T>();insertNode.rChild.value = value;}}}
}

7.遍历

二叉排序树采用中序遍历即可获得一个有序序列,代码如下:

/// <summary>
/// 遍历(中序)二叉排序树并返回一个有序list(默认升序)
/// </summary>
/// <param name="root">二叉排序树的根节点</param>
/// <param name="isUp">true:升序;false:降序</param>
public static List<T> QueryBSTree<T>(BSTree<T> root, bool isUp = true) where T : IComparerSearch
{List<T> list = new List<T>();QueryBSTree(root, isUp, ref list);return list;
}private static void QueryBSTree<T>(BSTree<T> node, bool isUp, ref List<T> list) where T : IComparerSearch
{if (node == null)return;if (isUp){// 中序遍历(升序)QueryBSTree(node.lChild, isUp, ref list);list.Add(node.value);QueryBSTree(node.rChild, isUp, ref list);}else{// 降序QueryBSTree(node.rChild, isUp, ref list);list.Add(node.value);QueryBSTree(node.lChild, isUp, ref list);}
}

8.删除

二叉排序树的删除稍微复杂一些,分如下4中情况:

1)要删除的是叶子节点,则直接删除即可,如下图:

2)要删除的节点A(33)仅有左子树时,则将被移除节点A的左子树赋值给A的父节点的左子树,并移除A,如下图:

3)要删除的节点A(77)仅有右子树时,则将被移除节点A的右子树赋值给A的父节点的右子树,并移除A,如下图:

4)要删除的节点A同时存在左右子树

此时比较简单的思路是:将节点A的左右子树中的一支(比如:右子树)作为替换节点,挂接在A的父节点下,并将A的另一支子树(左子树)下的所有节点重新插入到A的原右子树节点下;这是个比较笨的方法,思路比较简单,但是也很有可能增加数的深度,并且插入还增加了删除的成本

所以我们介绍另一种删除的思路:我们尝试找A的左右子树中某一个节点B来代替A,使得B替换A后,B也是一颗二叉排序树,并且不需要对左右子树节点进行重新插入;参见下图:

当我们要删除节点52时,可以选择左子树的最大值45,或是右子树的最小值58来代替52,并且替换后新节点也是一颗二叉排序树,这里我们以固定取左子树最大值来替换为例讲解,分以下两种情况:

1】要删除节点A(52)的左子树B(36)没有右子树时,则先将A(52)的右子树C(58)赋给B(36)的右子树,然后将B(36)赋给A(52)的父节点,如下图:

 2】要删除节点A(52)的左子树B(36)有右子树时,则循环找到最大的右子树节点C(45)用于替换A,并将节点C(45)的左子树D(39)赋给节点B(36)的右子树,如下图:

代码如下:

/// <summary>
/// 二叉排序树移除一个元素
/// </summary>
// <typeparam name="T">实现IComparerSearch的泛型数据</typeparam>
// <param name="key">查找的值(同IComparerSearch的GetCompareValue()返回值相比较)</param>
// <param name="root">二叉排序树的节点</param>
public static bool RemoveBSTree<T>(int key, ref BSTree<T> root) where T : IComparerSearch
{if (root == null)return false;// 找到需要移除的节点if (root.value.GetCompareValue() == key){if (root.lChild != null && root.rChild != null){// 左右子树都不为空(移除key对应的节点数据,并取左子树最大的节点作为新的节点数据替换)BSTree<T> coverNode = root.lChild;if (coverNode.rChild == null){// 左子树没有右子节点,则直接把左子树替换到移除位置coverNode.rChild = root.rChild;root = coverNode;}else{// 取左子树最大的节点作为新的节点数据替换BSTree<T> coverParent = root;while (coverNode.rChild != null){coverParent = coverNode;coverNode = coverNode.rChild;}if (coverNode.lChild != null)coverParent.rChild = coverNode.lChild;elsecoverParent.rChild = null;coverNode.lChild = root.lChild;coverNode.rChild = root.rChild;root = coverNode;}}else if (root.lChild != null){// 左子树不为空root = root.lChild;}else if (root.rChild != null){// 右子树不为空root = root.rChild;}else{// 左右子树均为空,移除当前节点即可root = null;}return true;}else if (key < root.value.GetCompareValue()){// 左子树查找return RemoveBSTree(key, ref root.lChild);}else{// 右子树查找return RemoveBSTree(key, ref root.rChild);}
}

9.示例

// 泛型数据结构
public class SearchData : IComparerSearch
{public int id;public int GetCompareValue(){return this.id;}public void Output(){Debug.Log($"id = {id}");}
}private List<SearchData> searchDataList = new List<SearchData>();
private Search.BSTree<SearchData> root = new Search.BSTree<SearchData>();private void Start()
{SearchExecute();
}private void SearchExecute()
{// 生成二叉排序树Search.ClearBSTree(root);root = new Search.BSTree<SearchData>();RandomInitSerachDataList(0, 100, 10);for (int i = 0; i < searchDataList.Count; i++){Search.InsertBSTree(root, searchDataList[i]);}OutputSerachDataList(searchDataList);// 查询并返回一个升序序列searchDataList = Search.QueryBSTree(root);OutputSerachDataList(searchDataList);
}// 删除序列中的一个随机数值
private void Remove()
{if (searchDataList == null || searchDataList.Count == 0)return;int index = UnityEngine.Random.Range(0, searchDataList.Count);int key = searchDataList[index].GetCompareValue();Debug.LogWarning($"[Remove] key = {key}");// 二叉排序树移除Search.RemoveBSTree(key, ref root);searchDataList = Search.QueryBSTree(root);OutputSerachDataList(searchDataList);
}// 随机生成maxCount个数据
private void RandomInitSerachDataList(int min, int max, int maxCount)
{SearchData data = null;searchDataList.Clear();for (int i = 0; i < maxCount; ++i){data = new SearchData();data.id = UnityEngine.Random.Range(min, max + 1);searchDataList.Add(data);}
}// 数据打印
private void OutputSerachDataList(List<SearchData> list)
{Debug.Log("----------------------------------------");for (int i = 0; i < list.Count; ++i){list[i].Output();}
}

随机生成5个数后的二叉排序树查询输出如下:

 

 

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

相关文章

  1. 为什么使用token?session与token的区别

    目录一、session的状态保持及弊端二、token认证机制 一、session的状态保持及弊端 当用户第一次通过浏览器使用用户名和密码访问服务器时,服务器会验证用户数据,验证成功后在服务器端写入session数据,向客户端浏览器返回sessionid,浏览器将sessionid保存在cookie中,当用户…...

    2024/4/18 2:53:51
  2. npm run serve报错

    npm run serve/dev报错 1、TypeError: compilation. templatesPlugin is not a function的解决 原因是因为你的webpack不是最新版本,但是install去下载也不是最新,所以这里我们要手动下载 运行命令: npm add webpack@latest 2、TypeError: Cannot read property ‘vue’ of un…...

    2024/4/15 21:46:02
  3. 乙级 - 1004 成绩排名 (20分)

    读入 n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。 输入格式 每个测试输入包含 1 个测试用例,格式为 第 1 行:正整数 n 第 2 行:第 1 个学生的姓名 学号 成绩 第 3 行:第 2 个学生的姓名 学号 成绩... ... ... 第 n+1 行:第 n 个学…...

    2024/4/9 19:05:21
  4. 测评分享丨OK3399-C开发板+RK1808人工智能计算棒(主动模式)

    一、 硬件平台平台:OK3399-C系统: Desktop模块: TB-RK1808S0环境准备:飞凌OK3399-C 开发板, rk1808 人工智能计算棒(固件版本为 V1.3.4 ) , usb 摄像头,摄像头和计算棒都插入 OK3399-C开发板 。使用 lsusb 命令查看,如下( 红框 部分 2207:0018 即为 RK1808 人工智能…...

    2024/4/9 19:05:20
  5. 李昱山:7.14黄金原油午间欧盘行情走势分析解套

    做黄金和原油,大多数投资者会受到行情的涨跌影响操作思路,坚守初心,方得始终,说的貌似简单,但是能做到的少之又少,这也就是为什么市场大多数人亏损的原因,短线操作大家存在一个误区,做空怕涨,做多怕跌,大家要知道没有人能够每次操作最低位做多,最高位做空,短线都会…...

    2024/4/9 19:05:19
  6. 用DHT11、DHT12和51单片机进行温湿度监测、传输与显示

    用DHT11、DHT12进行温湿度监测、传输与显示 总述总体功能监测传输显示软件监测端软件接收端软件硬件监测端接收端不足 ) 总述 这是我本科毕业设计的主要内容,毕设已于2020年5月结束,后来就一直想着花了这么久辛辛苦苦做的毕设如果就这么结束了很亏,说不定会有更多的人也需要…...

    2024/4/9 18:51:50
  7. 制作mobi格式的mingw+vs2013静态编译最新PostgreSQL文档

    1、下载源代码: git clone -b REL_10_STABLE git://git.postgresql.org/git/postgresql.git pg10 cd pg10 git branch [root@localhost postgresql]# git branch * REL_10_STABLE 2、安装对应依赖包: yum install docbook-dtds docbook-style-xsl fop libxslt opensp 参考:h…...

    2024/4/9 18:51:49
  8. 配置yum仓库

    !!!以下操作如无特殊说明均以root用户操作 准备工作 操作系统镜像 在配置YUM仓库前,需要准备操作系统的安装光盘镜像,准备的方式有两种:将操作系统的安装镜像文件(.ISO)上传到服务器 将操作系统的安装光盘直接插入光驱 !!!由于后期可能经常用到YUM仓库,建议采用前一…...

    2024/4/11 7:10:15
  9. Bag of Tricks for Image Classification with Convolutional Neural Networks阅读笔记

    Bag of Tricks for Image Classification with Convolutional Neural Networks —— 使用卷积神经网络进行图像分类的技巧包 文章目录Bag of Tricks for Image Classification with Convolutional Neural Networks —— 使用卷积神经网络进行图像分类的技巧包摘要1、介绍论文大…...

    2024/4/9 18:51:47
  10. 记录编译jemeter 5.3源码记录

    参考文档:https://testerhome.com/topics/24330 实践记录: NewDriver 位置 Jemeter/src/launcher/src/main/java/org.apache.jmeter/NewDriver...

    2024/4/19 7:25:32
  11. java过滤节假日周末返回工作日信息util

    需求:传入指定日期,判断是否为工作日,如果不是返回下一个工作日设计思路流程图:因每年部分节假日有不确定因数,不好判断,只有等国家发布下一年节假日信息。查询网上资料方法有多种1、调用api查询节假日信息,稳定的收费,免费的不怎么稳定2、网页抓取节假日信息3、自己建…...

    2024/4/19 19:01:40
  12. 币圈禁忌你知道多少?

    进入币圈的人都知道,币圈变化莫测,就连比特币的价格都起起伏伏,让人捉摸不透,况且现在币圈环境复杂,我们在投资的时候还会遇到各种各样的骗局陷阱,所以不得不小心谨慎。 币圈套路太多,我们经常遇到的就是这几种 最为一个币圈新手,我们要面对的就是各种各样的信息,这些…...

    2024/4/18 21:41:18
  13. vux selector下拉选择组件数据改变页面不渲染

    情景:移动端vux 的 selector下拉组件选择内容时,要判断页面上某些值是否存在,若存在就调取接口,不存在就是清空selector下拉组件刚选择的内容,并给出提示信息<selectortitle="<span class=star>*</span>到访时间"v-model="formData.visitCo…...

    2024/4/9 19:05:15
  14. Linux LVM与磁盘配额

    LVM概述逻辑卷管理 动态调整磁盘容量,从而提高磁盘管理的灵活性 /boot分区用于存放引导文件,不能基于LVM创建 图形界面管理工具 system-config-lvmPV 物理卷 物理卷是LVM机制的基本存储设备,通常对应为一个普通分区或整个硬盘。创建物理卷时,会在分区或硬盘的头部创建一个保…...

    2024/4/9 19:05:14
  15. 基于FPGA双通道DDS信号发生器

    原文链接:点此跳转到原文处...

    2024/4/11 18:30:03
  16. 在MYSQL数据库中,聚合函数不能出现在where子句的原因

    聚合函数出现在where子句中是个伪命题!举个简单的例子,现在需要select出所有员工中那些工资大于平均工资的员工信息,如果sql语句写成select * from 表名 where sal > avg(sal);肯定是要报错的。因为聚合函数的实现,是基于所有完整数据的基础上,例如,求和,统计数据总数…...

    2024/4/9 19:05:13
  17. 晨控rfid识别系统在中国重汽汽车橡胶密封件切割线上应用

    前言济南橡塑件有限公司是隶属于中国重汽集团的轮胎制品公司,位于济南市,其的经营范围包括汽车橡胶制品的研发、制造、销售、技术咨询,在其的工厂装配有多条橡胶切割生产线。本次与广州晨控智能技术有限公司合作的主要目的是提高橡胶切割线的智能化程度,解放线上劳动力。通…...

    2024/4/9 19:05:12
  18. vertica的常用命令

    基于列存储的数据库,相对于传统的基于行的数据库,它更适合在数据仓库存储方面发挥特长。基于列存储的数据库的优点: a)、对于聚集操作,比如求sum,明显基于列存储的要比基于行存储的快; b)、对于update操作,不须接触其他列值; c)、基于行存储的数据库在查询每行记录的多…...

    2024/4/15 11:24:45
  19. centos随机生成密码

    要安装expectyum -y install expect安装完成就可以使用 常用参数-l # (密码的长度定义, 默认是 9)-d # (数字个数, 默认是 2)-c # (小写字符, 默认是 3)-C # (大写字符, 默认是 2)-s # (特殊字符, 默认是 1)例如: [root@localhost ~]#mkpasswd -l 1…...

    2024/4/19 5:46:01
  20. 开放指定端口命令

    开放指定端口开放指定端口命令 开放指定端口命令 开放指定端口 : sudo firewall-cmd --zone=public --add-port= 27017/tcp --permanent 重新载入 : sudo firewall-cmd --reload...

    2024/4/9 19:05:10

最新文章

  1. python中的字典(dict)排序

    前言 在Python中&#xff0c;字典&#xff08;dict&#xff09;本身是无序的&#xff0c;直到Python 3.7版本&#xff0c;字典在迭代时会保持插入顺序。如果你需要根据键&#xff08;key&#xff09;或值&#xff08;value&#xff09;对字典中的项进行排序&#xff0c;可以使…...

    2024/4/19 22:35:01
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. ChatGPT 初学者指南

    原文&#xff1a;ChatGPT for Beginners 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 介绍 如果您一直关注新闻和趋势&#xff0c;您可能已经在某个地方读到或听到过&#xff0c;Sam Altman 的生成式人工智能平台 ChatGPT 已经将人工智能推向了一个新的高度 - 许多…...

    2024/4/19 9:32:02
  4. springboot 项目整合easy-captcha验证码功能

    效果 1、验证码使用easy-captcha,在pom文件增加依赖 <!-- google 验证码 --><dependency><groupId>com.github.whvcse</groupId><artifactId>easy-captcha</artifactId></dependency> 2、增加获取kaptcha的ctrl package com.*.*.s…...

    2024/4/18 20:00:56
  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/4/19 19:02:10
  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/4/19 11:51:49
  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/4/19 11:33:34
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

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

    2024/4/19 11:52:08
  9. VB.net WebBrowser网页元素抓取分析方法

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

    2024/4/19 2:38:12
  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/4/19 1:39:20
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

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

    2024/4/19 11:52:49
  12. 【ES6.0】- 扩展运算符(...)

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

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

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

    2024/4/18 23:06:50
  14. Go语言常用命令详解(二)

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

    2024/4/18 21:25:02
  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/4/18 18:47:03
  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/4/18 15:01:51
  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/4/19 3:53:57
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

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

    2024/4/19 19:50:16
  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/4/18 21:24:56
  20. 基于深度学习的恶意软件检测

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

    2024/4/19 11:54:11
  21. JS原型对象prototype

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

    2024/4/18 21:24:54
  22. C++中只能有一个实例的单例类

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

    2024/4/19 10:00:05
  23. python django 小程序图书借阅源码

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

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

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

    2024/4/19 2:37:58
  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