C++ hashtable
文章目录
- 1. 基本概念
- 2. 哈希函数
- 3. 哈希冲突及解决方法
- 开放定址法
- 链地址法
- 再哈希法
- 建立公共溢出区
- 4. 哈希表的操作实现
- 5. 内存管理及优化
- 时间复杂度
- 理想情况(无哈希冲突或冲突极少)
- 一般情况(考虑哈希冲突及解决方法)
- 综合来看
以下是关于哈希表(Hashtable)实现原理的详细介绍:
1. 基本概念
哈希表是一种数据结构,它提供了快速的插入、查找和删除操作,其核心思想是通过一个哈希函数(Hash Function)将数据的关键键(Key)映射为一个固定长度的哈希值(Hash Value),然后利用这个哈希值来确定数据在表中的存储位置,也就是索引(Index)。
2. 哈希函数
- 作用:
哈希函数负责把各种各样的输入键(通常键的数据类型多样,比如整数、字符串等)转化为一个相对固定范围的整数(哈希值)。理想的哈希函数应该具有以下特性:- 确定性:对于相同的输入键,每次计算得到的哈希值都应该相同,保证数据能准确存储和查找。
- 均匀分布性:尽可能使不同的输入键均匀地映射到哈希表的各个存储位置上,避免出现大量数据集中映射到少数几个位置(即哈希冲突)的情况。
- 高效性:能够快速地计算出哈希值,减少计算时间成本。
- 示例:
- 对于整数键,简单的取模运算可以作为一种哈希函数,比如
hash(key) = key % table_size
,这里table_size
是哈希表的大小(即存储位置的总数)。 - 对于字符串键,一种常见的做法是将字符串中每个字符的ASCII码值进行加权求和后再取模,例如:
- 对于整数键,简单的取模运算可以作为一种哈希函数,比如
int hash(const std::string& key){int hash_value = 0;for (size_t i = 0; i < key.length(); ++i) {hash_value += (int)key[i] * (i + 1);}return hash_value % table_size;
}
3. 哈希冲突及解决方法
以下是几种常见的解决哈希冲突的方法:
开放定址法
-
基本原理:
当通过哈希函数计算得到的存储位置已经被占用(即发生哈希冲突)时,按照某种探测规则在哈希表中寻找下一个空闲的存储位置来存放冲突的数据。 -
具体方式:
- 线性探测:
- 探测规则:在发生冲突后,依次从冲突位置往后顺序查找空闲的存储位置,也就是以固定的步长(通常为1)逐个探测后续的位置。例如,假设哈希表的大小为10,哈希函数计算出某个键对应的哈希值为3,但位置3已被占用,那么就依次检查位置4、5、6……直到找到空闲位置存放该键值对。
- 优点:实现简单,易于理解和编码实现,不需要额外的数据结构来辅助解决冲突。
- 缺点:容易出现数据堆积现象,也就是连续的多个键值对可能因为冲突而聚集在一起,形成较长的“聚集链”,这会导致后续的查找、插入操作效率降低,特别是在哈希表比较满的时候更为明显。例如,若很多键值对经过哈希函数计算后初始哈希值都集中在某个范围,后续采用线性探测时就容易在这一范围附近堆积大量数据。
- 二次探测:
- 探测规则:在发生冲突后,按照与冲突位置的距离呈二次函数关系的顺序去寻找空闲位置。通常先探测与冲突位置间隔为 (12)、(22)、(3^2) 等的位置,即若初始哈希值为 (h),第一次探测位置为 (h + 1^2),第二次探测位置为 (h + 2^2),以此类推(也可以采用类似 (h - 1^2)、(h - 2^2) 等向前探测的方式)。例如,哈希值为5的位置冲突了,先探测 (5 + 1^2 = 6) 位置,若不行再探测 (5 + 2^2 = 9) 位置等。
- 优点:相对线性探测而言,在一定程度上能够避免数据过度堆积的问题,使得数据在哈希表中的分布更均匀一些,从而提高查找和插入操作的效率。
- 缺点:不能完全消除数据堆积的情况,而且计算探测位置的过程相对复杂一点,需要进行更多的计算,增加了一定的时间成本;另外,在哈希表快满时,二次探测的效果也会大打折扣,甚至可能出现无法找到空闲位置的情况(尽管这种情况相对少见)。
- 双重哈希:
- 探测规则:使用两个不同的哈希函数 (h_1(key)) 和 (h_2(key)),当发生冲突时,通过公式 (h(key) = (h_1(key) + i \times h_2(key)) % table_size)(其中 (i) 为探测次数,从 (0) 开始递增,(table_size) 为哈希表的大小)来确定后续的探测位置。例如,第一个哈希函数计算出初始哈希值为 (3),第二个哈希函数计算出值为 (2),当冲突发生时,第一次探测位置是 ((3 + 0 \times 2) % table_size),第二次探测位置是 ((3 + 1 \times 2) % table_size) 等。
- 优点:通过两个哈希函数的配合,能更有效地避免数据堆积,使数据在哈希表中的分布更加均匀,在合适的参数选择下,可以获得较好的查找和插入性能。
- 缺点:需要设计和维护两个哈希函数,增加了代码实现的复杂性和计算开销;并且要合理选择两个哈希函数,否则可能达不到预期的效果,甚至可能出现循环探测找不到空闲位置的问题(不过通过合适的设计可以尽量避免这种情况)。
- 线性探测:
链地址法
-
基本原理:
把哈希值相同的数据(键值对)用链表连接起来,形成一个个“桶”。当有新的数据产生哈希冲突时,就将其添加到对应哈希值所在的链表末尾。每个链表可以看作是一个存储具有相同哈希值的键值对的集合。 -
优点:
- 实现相对简单,易于理解和编码实现,只需要在哈希表的基础上额外维护链表结构即可。
- 处理冲突的效率较高,对于插入操作,只要找到对应的链表头,然后在链表末尾添加新节点即可;查找操作也是先定位到对应的链表,再在链表中顺序查找目标数据,平均查找时间复杂度取决于链表的长度,在链表长度较短时,性能较好。
- 不会像开放定址法那样出现数据堆积影响整个哈希表性能的问题,因为每个链表相对独立,即使某个哈希值对应的链表较长,对其他哈希值对应的链表以及整个哈希表的其他操作影响不大。
-
缺点:
需要额外的内存空间来存储链表节点,如果哈希表中存在大量的哈希冲突,导致某些链表很长,那么除了存储键值对本身的数据内存外,还会消耗较多的链表节点内存,可能在一定程度上影响内存的利用效率;另外,在链表较长时,查找操作的时间复杂度会有所增加,不过可以通过一些优化手段(如将链表转换为更高效的数据结构,像红黑树等,当链表长度超过一定阈值时进行转换)来缓解这个问题。
再哈希法
-
基本原理:
当发生哈希冲突时,换用另一个哈希函数重新计算哈希值,期望通过新的哈希函数能够得到一个空闲的存储位置。如果新的哈希值仍然冲突,就继续更换哈希函数再次计算,直到找到空闲位置或者达到设定的最大尝试次数等限制条件为止。 -
优点:
可以根据不同的冲突情况灵活选择不同的哈希函数来优化数据的存储位置,有可能找到更合适的、分布更均匀的存储方式,减少冲突带来的影响。 -
缺点:
需要准备多个不同的哈希函数,增加了代码的复杂性和维护成本;而且频繁更换哈希函数会带来较高的计算开销,尤其是如果尝试多次都无法有效解决冲突时,会严重影响哈希表操作的整体效率;此外,很难保证换用的哈希函数一定能找到空闲位置,可能陷入不断尝试却始终无法妥善解决冲突的困境。
建立公共溢出区
-
基本原理:
在哈希表之外,额外开辟一块连续的存储区域作为公共溢出区。当发生哈希冲突时,将冲突的数据统一存放到这个公共溢出区中,可以通过记录指针或者索引等方式来关联原哈希表中的位置和公共溢出区中的存储位置,便于后续查找等操作。 -
优点:
能够保证哈希表本身的结构相对简单,不会因为解决冲突而使哈希表内部的存储结构变得复杂,便于对哈希表的其他操作(如遍历等)进行管理;而且对于公共溢出区,可以采用更灵活的存储和管理方式,比如根据数据量动态调整其大小等。 -
缺点:
增加了额外的存储区域,需要更多的内存空间来支持;查找操作相对复杂一些,需要先在哈希表中查找,如果没找到再去公共溢出区查找,增加了一次额外的查找步骤,可能会影响查找的效率,尤其是在公共溢出区数据量较大时更为明显。
不同的哈希冲突解决方法各有优缺点,在实际应用中需要根据具体的使用场景、数据特点以及性能要求等因素综合考虑来选择合适的方法。
4. 哈希表的操作实现
- 插入操作:
- 首先,通过哈希函数计算要插入数据的键对应的哈希值,确定其在哈希表中的大致存储位置。
- 如果该位置没有数据(不存在哈希冲突),则直接将数据存储在该位置;如果发生哈希冲突,根据所采用的冲突解决方法(如开放定址法进行探测找空闲位置,或者链地址法添加到对应链表末尾等)来妥善放置数据。
- 查找操作:
- 同样先利用哈希函数算出要查找数据的键对应的哈希值,定位到对应的存储位置或“桶”。
- 如果是采用开放定址法解决冲突,按照相应的探测规则查找目标数据;如果是链地址法,就在对应的链表中逐个查找,直到找到目标数据或者遍历完链表确定未找到。
- 删除操作:
- 先通过哈希函数找到目标数据所在位置,再依据冲突解决方式来进行删除。对于开放定址法,要谨慎处理删除后的空闲位置标记等问题,避免影响后续查找等操作的正确性;对于链地址法,直接从链表中删除相应节点即可。
5. 内存管理及优化
- 在内存中,哈希表的存储结构根据实现方式有所不同。采用开放定址法时,通常就是一个连续的数组结构来存放数据;采用链地址法时,除了有用于存储数据大致位置的数组(存放指向链表头的指针等),还需要为各个链表分配额外的内存空间用于存储节点。
- 为了优化哈希表的性能,可以根据实际应用场景合理选择哈希函数、冲突解决方法以及哈希表的大小等参数。例如,根据预估的数据量来调整哈希表大小,避免过于频繁的哈希冲突;定期对哈希表进行重构(比如重新计算哈希值、调整存储位置等)来优化数据分布,提高整体效率。
总之,哈希表通过巧妙地运用哈希函数和解决哈希冲突的机制,实现了高效的数据存储、查找和删除操作,在众多领域如数据库、编译器、缓存系统等都有着广泛的应用。
哈希表的时间复杂度在不同操作以及不同情况下有所差异,以下是对其插入、查找和删除操作时间复杂度的详细分析:
时间复杂度
理想情况(无哈希冲突或冲突极少)
- 插入操作:
在理想状态下,通过哈希函数能将每个键均匀且唯一地映射到哈希表的不同位置,插入操作只需要计算键对应的哈希值,然后将数据存放到对应的位置即可,这个过程通常可以在常数时间 (O(1)) 内完成。例如,有一个足够大且设计良好的哈希表,插入少量不同的键值对时,几乎不会产生哈希冲突,每次插入都能迅速定位到空闲位置进行存储。 - 查找操作:
同样,当不存在哈希冲突时,查找一个键对应的键值对,只需根据键计算出哈希值,然后直接访问该哈希值对应的位置就能确定是否找到目标,时间复杂度也是 (O(1))。就好比在一个完美的哈希表中找某个元素,一次定位就能知晓结果。 - 删除操作:
类似于插入和查找操作,若没有哈希冲突,通过哈希值定位到要删除的数据所在位置后,直接进行删除处理,时间复杂度同样为 (O(1))。
一般情况(考虑哈希冲突及解决方法)
- 开放定址法:
- 插入操作:
平均情况下,插入操作的时间复杂度接近 (O(1)),不过在最坏情况下,如果哈希表接近满或者哈希函数设计不佳导致大量冲突,插入操作可能需要多次探测空闲位置,时间复杂度会退化为 (O(n)),其中 (n) 是哈希表的大小。例如,采用线性探测且不断有数据集中在少数几个哈希值对应的位置附近,插入新数据时可能要线性遍历很长一段已占用的位置去寻找空闲处。 - 查找操作:
平均情况下,查找操作的时间复杂度大约是 (O(1)),但在最坏情况下,比如数据聚集严重,查找一个键可能需要遍历哈希表中的大部分位置,时间复杂度会达到 (O(n))。 - 删除操作:
平均时间复杂度接近 (O(1)),然而在最坏情况下,由于要谨慎处理删除后留下的空闲位置(避免影响后续查找等操作的正确性,可能需要对后续数据进行重新整理等操作),时间复杂度也可能退化为 (O(n))。
- 插入操作:
- 链地址法:
- 插入操作:
插入操作首先要通过哈希函数定位到对应的链表,这个过程通常是 (O(1)),然后在链表末尾添加节点,平均时间复杂度取决于链表的平均长度,设链表平均长度为 (k),则插入操作的平均时间复杂度为 (O(1 + k)),在链表较短时,可近似看作 (O(1))。例如,一个哈希表采用链地址法,大部分链表长度较短,插入新键值对时找到对应链表后很快就能添加进去。 - 查找操作:
先通过哈希函数定位到链表是 (O(1)),然后在链表中查找目标键值对,平均时间复杂度同样取决于链表平均长度 (k),为 (O(1 + k)),若 (k) 较小,可认为接近 (O(1)),但在链表很长时,时间复杂度会升高,最坏情况下如果链表长度达到 (n)(哈希表大小),时间复杂度就是 (O(n))。 - 删除操作:
先定位到链表是 (O(1)),然后在链表中删除相应节点,平均时间复杂度取决于链表平均长度 (k),为 (O(1 + k)),类似查找操作,在不同链表长度情况下表现不同。
- 插入操作:
综合来看
哈希表在设计良好(哈希函数合理、冲突解决方法得当、哈希表大小合适等)的情况下,插入、查找和删除操作的平均时间复杂度都能接近 (O(1)),这使得它在很多需要快速查找、插入和删除数据的场景中有着广泛的应用。不过在极端或不良的条件下(比如哈希函数选择不当、数据量远超哈希表承载能力等),时间复杂度可能会恶化,所以在实际应用中要综合考虑各方面因素来优化哈希表的性能。
相关文章:
C++ hashtable
文章目录 1. 基本概念2. 哈希函数3. 哈希冲突及解决方法开放定址法链地址法再哈希法建立公共溢出区4. 哈希表的操作实现5. 内存管理及优化 时间复杂度理想情况(无哈希冲突或冲突极少)一般情况(考虑哈希冲突及解决方法)综合来看 以…...
ip怎么查域名?IP和域名分别是什么?
为什么我们可以通过简单的域名访问网站,而不是记住一串复杂的数字?IP地址和域名之间到底是什么关系?在互联网的世界里,IP地址和域名是两种重要的概念,它们共同构成了我们日常上网的基础。 IP地址是互联网协议地址的缩…...
大模型提示词初探
大模型提示词初探 在与大模型交互的过程中,提示词起着至关重要的作用,它犹如给模型下达的精准任务指令,直接影响着模型生成内容的准确性、高效性与合理性。合理运用提示词,能够有效减少模型出现错误和幻觉的情况,从而…...
Linux的进程替换以及基础IO
进程替换 上一篇草率的讲完了进程地址空间的组成结构和之间的关系,那么我们接下来了解一下程序的替换。 首先,在进程部分我们提过了,其实文件可以在运行时变成进程,而我们使用的Linux软件其实也是一个进程,所以进一步…...
《Vue进阶教程》第三十一课:ref的初步实现
往期内容: 《Vue进阶教程》第二十课:lazy懒执行 《Vue进阶教程》第二十一课:支持缓存 《Vue进阶教程》第二十二课:自定义更新(调度器) 《Vue进阶教程》第二十三课:渲染计算属性的结果 《Vue进阶教程》第二十四课&…...
Wend看源码-Java-集合学习(Queue)
概述 Wend看源码-Java-集合学习(List)-CSDN博客 Wend看源码-Java-集合学习(Set)-CSDN博客 在前两篇文章中,我们分别探讨了Java集合框架的父类以及List集合和Set集合的实现。接下来,本文将重点阐述Java中的Queue集合,包括其内部的数据结…...
大数据面试笔试宝典之HBase面试
1.HBase 数据存储位置 HBase 中的数据存储在哪里? 以什么格式存储?和 Zookeeper 什么关系? 参考答案: 1.HBase 中的所有数据文件都存储在 Hadoop HDFS 文件系统上。 2.包含两种文件类型: HFile : HBase 中 KeyValue 数据的存储格式。HFile 是 Hadoop 的二进制格式文件…...
React基础知识学习
学习React前端框架是一个系统而深入的过程,以下是一份详细的学习指南: 一、React基础知识 React简介 React是一个用于构建用户界面的JavaScript库,由Facebook开发和维护。它强调组件化和声明式编程,使得构建复杂的用户界面变得更…...
实战指南:Shiro、CAS打造完美单点登录体验
引言 想象一下,在日常工作中,我们经常需要进行系统认证和授权。当用户尝试登录一个网站时,他们需要提供用户名和密码,网站会检查这些信息,确认用户是谁。这就是认证的过程。 一旦用户被认证,他们可能会尝…...
光储充一体化解决方案详解。
一、光储充介绍 1、什么是光储充 “光储充”一体化,顾名思义,是由光伏发电、储能、充电集成一体、互相协调支撑的绿色充电模式。其工作原理是利用光伏发电,余电由储能设备存储,共同承担供电充电任务。在用电高峰,光储…...
TDengine 新功能 VARBINARY 数据类型
1. 背景 VARBINARY 数据类型用于存储二进制数据,与 MySQL 中的 VARBINARY 数据类型功能相同,VARBINARY 数据类型长度可变,在创建表时指定最大字节长度,使用进按需分配存储,但不能超过建表时指定的最大值。 2. 功能说明…...
2024年秋词法分析作业(满分25分)
【问题描述】 请根据给定的文法设计并实现词法分析程序,从源程序中识别出单词,记录其单词类别和单词值,输入输出及处理要求如下: (1)数据结构和与语法分析程序的接口请自行定义;类别码需按下表格…...
AF3 checkpoint_blocks函数解读
checkpoint_blocks 函数实现了一种分块梯度检查点机制 (checkpoint_blocks),目的是通过分块(chunking)执行神经网络模块,减少内存使用。在深度学习训练中,梯度检查点(activation checkpointing)是一种显存优化技术。该代码可以: 对神经网络的块(blocks)按需分块,并对…...
VITUREMEIG | AR眼镜 算力增程
根据IDC发布的《2024年第三季度美国AR/VR市场报告》显示,美国市场AR/VR总出货量增长10.3%。其中,成立于2021年的VITURE增长速度令人惊艳,同比暴涨452.6%,成为历史上增长最快的AR/VR品牌。并在美国AR领域占据了超过50%的市场份额&a…...
详解MySQL在Windows上的安装
目录 查看电脑上是否安装了MySQL 下载安装MySQL 打开MySQL官网,找到DOWNLOADS 然后往下翻,找到MySQL Community(GPL) Downloads>> 然后找到MySQL Community Server 然后下载,选择No thanks,just start my download. 然后双击进行…...
细说STM32F407单片机CAN基础知识及其HAL驱动程序
目录 一、CAN总线结构和传输协议 1、 CAN总线结构 (1)闭环结构的CAN总线网络 (2)开环结构的CAN总线网络 (3)隐性电平和显性电平 2、CAN总线传输协议 (1)CAN总线传输特点 &am…...
Ubuntu 22.04 升级 24.04 问题记录
一台闲置笔记本使用的 ubuntu 还是 18.04,最近重新使用,发现版本过低,决定升级,于是完成了 18.04 -> 20.04 -> 22. 04 -> 24.04 的三连跳。 一、升级过程中黑屏 主要问题是在 22.04 升级到 24.04 过程中出现了黑屏仅剩…...
模型选择+过拟合欠拟合
训练误差和泛化误差 训练误差:模型在训练数据上的误差 泛化误差:模型在新数据上的误差 验证数据集:一个用来评估模型好坏的数据集 例如拿出50%的数据作为训练 测试数据集:只能用一次 K则交叉验证 在没有足够数据时使用 算法…...
Leetcode 3404. Count Special Subsequences
Leetcode 3404. Count Special Subsequences 1. 解题思路2. 代码实现 题目链接:3404. Count Special Subsequences 1. 解题思路 这道题是事实上这次的周赛最难的一道题目,不过也是有点巧思在内。 最开始我的想法就是按照乘积构成pair,然后…...
萌萌哒的八戒
萌萌哒的八戒 下载压缩包后,打开发现有一张照片 既然是关于猪的,那就用猪圈密码解码 flag{whenthepigwanttoeat}...
开启家具组装新方式:产品说明书智能指导
在快节奏的现代生活中,人们越来越追求便捷与高效。无论是新房装修还是家具换新,家具组装已成为许多家庭不可避免的一项任务。然而,面对复杂多变的家具图纸和冗长的产品说明书,许多人常常感到无从下手,甚至因操作不当而…...
【连续学习之ResCL算法】2020年AAAI会议论文:Residual continual learning
1 介绍 年份:2020 会议: AAAI Lee J, Joo D, Hong H G, et al. Residual continual learning[C]//Proceedings of the AAAI Conference on Artificial Intelligence. 2020, 34(04): 4553-4560. 本文提出的算法是Residual Continual Learning (ResC…...
【网络协议】路由信息协议 (RIP)
未经许可,不得转载。 路由信息协议(Routing Information Protocol,简称 RIP)是一种使用跳数(hop count)作为路由度量标准的路由协议,用于确定源网络和目标网络之间的最佳路径。 文章目录 什么是…...
Linux 终端查看 nvidia 显卡型号
文章目录 写在前面1. 需求描述2. 实现方法方法一:方法二方法三: 参考链接 写在前面 自己的测试环境: Ubuntu20.04 1. 需求描述 Linux 终端查看 nvidia 显卡型号 2. 实现方法 方法一: 执行下列指令: sudo update…...
基于neurokit2的心电仿真数据生成实例解析
一 概念 NeuroKit2是一个开源的、社区驱动的、以用户为中心的Python库,可用于多种生理信号的分析处理(例如ECG、PPG、EDA、EMG、RSP),还包括用于特定处理步骤(如频率)的工具提取和过滤方法,并在…...
AMBA-APB
目录 1.APB 协议 2.APB信号列表 3.数据传输 3.1写传输(2种) 3.1.1 无等待状态的写传输 3.1.2有等待状态的写传输 3.2写选通信号 (PSTRB) 字节通道映射 3.3读传输(2种) 3.3.1 无等待状态的读传输 3.3.2有等待状态的读传…...
网安入门之PHP后端基础
PHP 基本概念详解 PHP是一种服务器端脚本语言,常用于动态网站开发和 web 应用程序。以下是 PHP 的基本概念与特点的详细说明: 1. PHP 文件的默认文件扩展名 PHP 文件的扩展名通常为 .php,例如 index.php。PHP 文件可以包含 PHP 代码、HTML…...
windows系统安装完Anaconda之后怎么激活自己的虚拟环境并打开jupyter
1.在win主菜单中找到Anaconda安装文件夹并打开终端 文件夹内有所有安装后的Anaconda的应用软件和终端窗口启动窗口 点击Anaconda Prompt(Anaconda)就会打开类似cmd的命令终端窗口,默认打开的路径是用户名下的路径 2.激活虚拟环境 使用命令…...
【C#特性整理】C#特性及语法基础
1. C#特性 1.1 统一的类型系统 C#中, 所有类型都共享一个公共的基类型. 例如,任何类型的实例都可以通过调用ToString方法将自身转换为一个字符串 1.2 类和接口 接口: 用于将标准与实现隔离, 仅仅定义行为,不做实现. 1.3 属性、方法、事件 属性: 封装了一部分对…...
龙蜥 配置本地yum源8.6----亲测
系统版本: 说明:丫丫的,内网服务安装了个龙蜥操作系统。内网不能访问互联网,所以就需要挂载yum源 用的以前的方法挂载,一直报错 [Couldnt open file /mnt/anolisos/repodata/repomd.xml] yum挂载的时候报错,奇葩!!!,龙蜥的挂载方法好像不一样。 解决: 一、上传并挂…...
Xshell日志录制
步骤 1:设置日志文件位置 打开 Xshell 软件,选择目标会话(或者创建一个新的会话)。右键点击会话名称,选择“属性”。在会话属性窗口中,找到“日志”选项卡。勾选“启用日志记录”。在“文件名”中设置日志…...
vue下载和上传的地址动态ip地址配置方法
vue3结合element-plus实现【下载文件】和【上传文件】的动态ip地址配置 效果图 一、修改【文件上传】静态地址 1、首先引入axios import axios from "/utils/request"; import { getToken } from "/utils/auth"; 定义 const importDialogVisible ref(…...
动手做计算机网络仿真实验入门学习
打开软件 work1 添加串行接口模块,先关电源,添加之后再开电源 自动选择连接 所有传输介质 自动连接 串行线 绿色是通的,红色是不通的。 显示接口。se是serial串行的简写。 Fa是fast ethernet的简写。 为计算机配置ip地址: 为服…...
LeetCode 面试题 17.10. 主要元素
LeetCode 面试题 17.10. 主要元素 数组中占比超过一半的元素称之为主要元素。给你一个 整数 数组,找出其中的主要元素。若没有,返回 -1 。请设计时间复杂度为 O(N) 、空间复杂度为 O(1) 的解决方案。 示例 1: 输入:[1,2,5,9,5,9,5…...
Hive之import和export使用详解
在hive-0.8.0后引入了import/export命令。 Export命令可以导出一张表或分区的数据和元数据信息到一个输出位置,并且导出数据可以被移动到另一个hadoop集群或hive实例,并且可以通过import命令导入数据。 当导出一个分区表,原始数据可能在hdf…...
SpringBoot数据字典字段自动生成对应code和desc
效果:接口会返回orderType,但是这个orderType是枚举的类型(1,2,3,4),我想多返回一个orderTypeDesc给前端展示,这样前端就可以直接拿orderTypeDesc使用了。 1. 定义注解 …...
HTML——16.相对路径
<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title></head><body><a href"../../fj1/fj2/c.html" target"_blank">链接到c</a><!--相对路径:-->…...
字——位级运算与有无符号数之间的比较
前言 本文整理和归纳《深入理解计算机系统》这本书的内容,但本文不会继续长篇大论地去将所有内容都总结,而是总结笔者认为容易遗忘或混淆或表述不清的内容。 字 首先字这个概念对于学习过《计算机体系结构》或《操作系统》的同学都不陌生,…...
Python爬虫教程——7个爬虫小案例(附源码)_爬虫实例
本文介绍了7个Python爬虫小案例,包括爬取豆瓣电影Top250、猫眼电影Top100、全国高校名单、中国天气网、当当网图书、糗事百科段子和新浪微博信息,帮助读者理解并实践Python爬虫基础知识。 包含编程资料、学习路线图、源代码、软件安装包等!【…...
‘Optional. get()‘ without ‘isPresent()‘ check
在Java中,Optional类被引入主要是为了解决NullPointerException的问题,它提供了一种更优雅的方式来处理可能为null的情况。Optional.get()方法用于获取Optional实例中包含的值,但如果Optional实例是空的(即没有值)&…...
015-spring-动态原理、AOP的xml和注解方式
强制使用cglib动态代理 spring-AOP的使用...
统计颜色Count Color(POJ2777)题解
有一个长度为L厘米板,L是一个正整数,所以我们可以把它均匀地划分成L个部分,分别从左到右编号为1,2……L,每一个部分长度都为1厘米。现在我们必须给每个部分涂色,一个部分一种颜色,要求完成以下两…...
Nginx 配置 SSL(HTTPS)详解
Nginx作为一款高性能的HTTP和反向代理服务器,自然支持SSL/TLS加密通信。本文将详细介绍如何在Nginx中配置SSL,实现HTTPS的访问。 随着互联网安全性的日益重要,HTTPS协议逐渐成为网站加密通信的标配。Nginx作为一款高性能的HTTP和反向代理服务…...
Day10补代码随想录 理论基础|232.用栈实现队列|225.用队列实现栈|20.有效的括号|1047.删除字符串中的所有相邻重复项
栈和队列理论基础 抽象认识 栈是先进后出(FIFO),队列是先进先出(LIFO) 队首(先进))队尾(后进)栈顶(后进)栈底(先进) 栈(Stack) 只在一端进行进出操作(只在一端进一端出)像个篮球框,取用篮球从一端进出。 /进栈 int a[1000];//足够大的栈空间 int top-1…...
pytorch基础之注解的使用--003
Title 1.学习目标2.定义3.使用步骤4.结果 1.学习目标 针对源码中出现一些注解的问题,这里专门写一篇文章进行讲解。包括如何自定义注解,以及注意事项,相信JAVA中很多朋友业写过,但是今天写的是Python哦。。。 2.定义 在 Python…...
2024-12-30-g++
title: 探秘 g:C 编程的得力编译器 date: ‘2024-12-30’ category: blog tags: gC 编程编译器技术代码生成与优化 sig: compiler archives: ‘2024-12’ author:way_back summary: g 作为专门用于 C 语言的编译器,在 C 开发领域占据关键地位。它凭借对…...
互联网十万个为什么之什么是微服务
微服务(Microservices)是一种软件架构设计模式,它将应用程序分解为小型、自治的服务单元,这些服务单元可以独立部署、扩展和维护,其中每一个服务单元也都是一个微服务。 基于微服务形成的软件架构风格称为微服务架构&…...
mysql子查询
子查询是嵌套在另一个 SELECT, INSERT, UPDATE, 或 DELETE查询的 SQL 查询。子查询可以在 WHERE 子句中、FROM 子句或 SELECT 列表中出现。 以下是一些使用 MySQL 子查询的常见示例: 1.在 WHERE 子句中使用子查询: SELECT * FROM Employees WHERE s…...
智能故障诊断和寿命预测期刊推荐
往期精彩内容: Python-凯斯西储大学(CWRU)轴承数据解读与分类处理 基于FFT CNN - BiGRU-Attention 时域、频域特征注意力融合的轴承故障识别模型-CSDN博客 基于FFT CNN - Transformer 时域、频域特征融合的轴承故障识别模型-CSDN博客 P…...
根据语言变化动态更新图片资源方案
根据语言变化动态更新图片资源方案 一、需求描述二、关于 Locale三、实现方案3.1 方案一(不可行)3.2 方案二(不可行)3.3 方案三 一、需求描述 Android 项目中引导页图片包含文字信息,由于应用是适配了三种语言&#x…...