首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏全栈程序员必看

    函数「建议收藏」

    是一种用于以常数平均时间执行插入、删除和查找的技术。 每个关键字被映射到从0-TableSize-1这个范围中的某个数,并且被放到适当的单元中。 这种映射就叫做函数 我认为,先用函数将我们所要进行操作的集合整合成列表,是对之后的操作的一种便利。放到实际中去,我们要进行操作的集合不仅仅只是数字,例如图书馆中的书籍分类等等。 我们可以通过某种规定,将每个关键字放到合适的为止上去,编写函数。但是难免会遇到两个关键词被单列到同一个值的情况,(称为冲突),如何解决冲突是一个很关键的问题,之后另开博。 int b[9]; int i; for(i = 0; i < 9; i++) { b[a[i]%10] = a[i]; //通过模10运算,将关键字合适的位置 设所有关键字最多8个字符长,由于char类型的值最多是127,因此这个函数之恩那个取值在0到27*8之间,若TableSize超过了1w,显然这并不是一种均匀的分配。

    1.4K30编辑于 2022-08-28
  • 来自专栏JMCui

    算法与

    原来是Groudhog类没有重写hashCode()方法,所以这里是使用Object的hashCode()方法生成码,而他默认是使用对象的地址计算码。 二、理解hashCode()      的价值在于速度:使得查询得以快速执行。 这个数字就是码,由定义在Object的hashCode()生成(或成为函数)。同时,为了解决数组容量被固定的问题,不同的“键”可以产生相同的下标。那对于数组来说? 备注:为使分布均衡,Java的函数都使用2的整数次方来作为列表的理想容量。对现代的处理器来说,除法和求余是最慢的动作。使用2的整数次方的列表,可用掩码代替除法。 也就是说,它必须基于对象的内容生成码。 应该产生分布均匀的码。如果码都集中在一块,那么在某些区域的负载就会变得很重。

    2.3K60发布于 2018-03-15
  • 来自专栏rikka

    复杂度分析: 顺序查找: O(n) 二分查找: O(\log_2n) 方法: O(C) 列表与方法 将一个元素的关键码和存储位置之间建立对应的函数关系 Hash( ), 使得每个关键码与结构中的唯一的存储位置相对应 : Address=Hash( ) 需要解决两个问题: 找到一个合适的函数,避免或尽量减少冲突 拟定解决冲突的方案 函数 取余法 列表中地址数位m, p为不大于m但最接近m的质数. 将结果化成八进制 处理冲突的闭(开地址)方法 产生冲突元素的关键码互为同义词. 闭又叫开地址法. 所有的桶都直接放在列表数组中,并且把该数组组织成环形结构. 每个桶只有一个元素. 当发生冲突时, 把这个元素存放进表中”下一个”空桶中.寻找空桶的方法有很多. 再 当表项数>表的70%时, 可以再. 即, 建立一个两倍大的表, 新的函数取距离原规模两倍大小最近的素数. 处理冲突的开(链地址)方法 将同义词放入同一个桶.

    2.2K30编辑于 2022-02-07
  • 来自专栏xingoo, 一个梦想做发明家的程序员

    选择键值,冲突的时候采取不同的策略 函数: 简单的函数: 1 int hash(const string & key,int tableSize) 2 { 3 int hashVal = hashVal % tableSize; 9 } 比较好的函数: 1 int hash( const string & key,int tableSize ) 2 { 3 int hashVal return hashVal; 8 } 使用name成员为键,提供的函数实例: 1 class Employee 2 { 3 public: 4 const string & getName ()) 8 rehash(); 9 10 return true; 11 } 装填因子:列表中的元素个数 与 列表大小的 比值 执行一次查找所需的时间:计算函数值所需要的常数时间加上遍历表所用的时间 if(oldArray[i].info == ACTIVE) 13 insert(oldArray[i].element); 14 } 15 } 对探测列表的再

    1.1K90发布于 2018-01-17
  • 来自专栏全栈程序员必看

    查找和哈希查找_检索

    采用技术将记录存在在一块连续的存储空间中,这块连续存储空间称为列表或哈希表。那么,关键字对应的记录存储位置称为地址。   技术既是一种存储方法也是一种查找方法。 技术的记录之间不存在什么逻辑关系,它只与关键字有关,因此,主要是面向查找的存储结构。 如果现在要存储某家公司的登记表,若用手机号作为关键字,极有可能前7位都是相同的,选择后四位成为地址就是不错的选择。若容易出现冲突,对抽取出来 的数字再进行反转、右环位移等。 2.5 除留余数法 此方法为最常用的构造函数方法。对于列表长为m的函数公式为: mod是取模(求余数)的意思。 综合以上等因素,才能决策选择哪种函数更合适。 处理冲突的方法   在理想的情况下,每一个关键字,通过函数计算出来的地址都是不一样的,可现实中,这只是一个理想。

    1.6K20编辑于 2022-11-15
  • 来自专栏文武兼修ing——机器学习与IC设计

    分离链接的代码实现

    列为一种用于以常数平均时间执行插入,删除和查找的技术。一般的实现方法是使通过数据的关键字可以计算出该数据所在中的位置,类似于Python中的字典。 关于需要解决以下问题: 的关键字如何映射为一个数(索引)——函数 当两个关键字的函数结果相同时,如何解决——冲突 函数 函数为关键字->索引的函数,常用的关键字为字符串,则需要一个字符串 ->整数的映射关系,常见的三种函数为: ASCII码累加(简单) 计算前三个字符的加权和$\sum key[i] * 27^{i}$ (不太好,3个字母的常用组合远远小于可能组合) 计算所有字符加权和并对长度取余 ,发生冲突,本次使用分离链接法解决: 每个中的数据结构有一个指针可以指向下一个数据,因此列表可以看成链表头的集合 当插入时,将数据插入在对应值的链表中 访问时,遍历对应值的链表,直到找到关键字 ,因此需要定义一个节点用于计算值 point := h.table[temp.hash].next for point !

    2.2K80发布于 2018-04-27
  • 来自专栏全栈程序员必看

    Hash

    为了速度而 HashMap速度总所周知是非常快的,但是为什么会这么快,是因为它的技术,下面简单理解一下知识 的价值在于速度,使得查询得以快速。 一般容器查询的速度的瓶颈位于键的查询,采取的做法一般是对键进行排序,但则不是 的特点 的做法,通常把键保存到某个地方,存储一组元素最快的数据结构就是数组,所以用它来保存键的信息(不是键本身 的做法,数组不保存键本身,而是通过键对象生成一个随机数字,用作数组的下标,这个数字就是我们通常见到的hashCode。 我们查询是通过查询对象计算出一个码,如果能保证没有冲突,重复,那就可能有了一个完美的函数。 slot 和 bucket 中的槽位(solt)通常称为桶位,以内实际列表的数组名称为bucket, 桶的数量都使用质数。

    1K10编辑于 2022-08-27
  • 来自专栏全栈程序员必看

    冲突

    概念:如果当一个元素被插入时与一个已经插入的元素列到相同的值, 那么就会产生冲突, 这个冲突需要消除。 为执行一次查找,我们使用函数来确定是那一个链表, 然后我们在被确定的链表中执行一次查找。 = 0 && n % 7 ! = 0) return true; else return false; } /* * 对分离链接列表和探测列表的在 = 0 && n % 7 !

    98710编辑于 2022-08-27
  • 来自专栏以终为始

    7-15 逆问题 (30 分)

    7-15 逆问题 (30 分) 给定长度为 N 的列表,处理整数最常用的映射是 H(x)=x%N。 如果我们决定用线性探测解决冲突问题,则给定一个顺序输入的整数序列后,我们可以很容易得到这些整数在列表中的分布。 例如我们将 1、2、3 顺序插入长度为 3 的列表HT[]后,将得到HT[0]=3,HT[1]=1,HT[2]=2的结果。 但是现在要求解决的是“逆问题”,即给定整数在列表中的分布,问这些整数是按什么顺序插入的? 输入格式: 输入的第一行是正整数 N(≤1000),为列表的长度。 第二行给出了 N 个整数,其间用空格分隔,每个整数在序列中的位置(第一个数位置为0)即是其在列表中的位置,其中负数表示表中该位置没有元素。题目保证表中的非负整数是各不相同的。

    29730编辑于 2023-03-09
  • 来自专栏全栈程序员必看

    查找

    一、的概念 同顺序、链接和索引一样,是又一种数据存储方法。 在列表上进行查找时,首先根据给定的关键字k,用与存储时使用的同一函数h(k)计算出地址,然后按此地址从列表中取出对应的元素。 结合例10-1 ,n=7,所以假定取m=3,则得到的每个元素的地址为: h(18)=18%13=5 h(60)=60%13=8 h(54)=54%13=2 h(46)=46%13=7 二、函数 构造函数的目标是使函数尽可能均匀地分布在地址的空间上,同时使计算尽可能简单,以节省时间。 它的缺点是不能探查到列表上的所有单元,但至少能探查到一半单元(证明从略)。例如,当d0=5,m=17时,只能探查到单元地址依次为5、6、9、14、4、13、7、3、1的单元,而不能探查到剩余的单元。

    1.9K10编辑于 2022-08-27
  • 来自专栏linux驱动个人学习

    函数

    概念 的概念属于查找,它不以关键字的比较为基本操作,采用直接寻址技术。在理想情况下,查找的期望时间为O(1)。 hash函数就是把任意长的输入字符串变化成固定长的输出字符串的一种函数。 (Hashing)通过函数将要检索的项与索引(值)关联起来,生成一种便于搜索的数据结构(列表)。 应用 目前应用最为广泛的hash函数是SHA-1和MD5,大多是128位和更长。 (1)函数的计算简单,快速; (2)函数能将关键字集合K均匀地分布在地址集{0,1,…,m-1}上,使冲突最小。 通过平方扩大差别,另外中间几位与乘数的每一位相关,由此产生的地址较为均匀。这是一种较常用的构造哈希函数的方法。 (0100,0110,1010,1001,0111) 平方后得(0010000,0012100,1020100,1002001,0012321) 若取表长为1000,则可取中间的三位数作为地址集

    1.3K30发布于 2019-09-24
  • 来自专栏动态规划

    C++ —— 哈希详解 - 开与闭

    哈希的概念 哈希(hash)⼜称,是⼀种组织数据的⽅式。从译名来看,有散乱排列的意思。 当使⽤除法法时,建议M取不太接近2的整数次冥的⼀个质数(素数) 1.4.2 乘法法 1. 这种情况是可以存在的,只要函数是公开且确定的,就可以实现此攻击。解决⽅法⾃然是⻅招拆招,给函数增加随机性,攻击者就⽆法找出确定可以导致最坏情况的数据。这种⽅法叫做全域 2. 需要注意的是每次初始化哈希表时,随机选取全域函数组中的⼀个函数使⽤,后续增删查改都固定使⽤这个函数,否则每次哈希都是随机选⼀个函数,那么插⼊是⼀个函数,查找⼜是另⼀个函数,就会导致找不到插 双重 1.

    61300编辑于 2024-11-19
  • 来自专栏wym

    Hash()冲突解决 线性探测再和二次探测再

    线性探测再 例如  哈希函数为: H(key) =  key %13,key 为关键字,采用开放地址法中的线性探测再解决冲突,依次输入 11 个关键字,16,74,60,43,54,90,46, 二次探测再 例如  哈希函数为: H(key) =  key %13,key 为关键字,采用开放地址法中的二次探测再解决冲突,依次输入 10 个关键字,36,21,45,17,29,55,35,

    17.4K20发布于 2018-12-28
  • 来自专栏明丰随笔

    浅谈运算

    运算是什么? 运算具有4个特点: 1. 运算是不可逆的,可以将运算理解为单向的加密:根据原消息经过运算可以得到摘要(密文);但是根据摘要,无法推导出原消息。 2. 利用运算判断消息是否被篡改: 1.发送方对消息进行运算,得到消息摘要(原始摘要),发送消息和摘要,并说明获得摘要所使用的算法,如MD5。 密钥运算类型的使用和普通的运算类似,不过多传了一个密钥作为参数而已。 运算具有4个特点 算法保证了消息的完整性 算法与密钥算法 .Net中对运算支持

    1.6K20发布于 2019-07-24
  • 来自专栏CoffeeLand

    hash introduction

    Table of Content hash概念 hash冲突 构造hash hash的应用 hash概念 hash是在记录的存储位置与他的关键字之间建立的对应关系f, 使得每个key都对应一个存储位置 这个hash函数也被称为hash table address = f(key) hash是一种查找的存储技术. hash冲突 每一个key对应一个address, 当key1 ! = key2, f(key1) == f(key2),这种情况被称为hash冲突(collision) 构造hash hash的应用 cryptography, compression, checksum

    71520发布于 2020-03-26
  • 来自专栏全栈程序员必看

    查找-查找

    那么关键字对应的记录存储位置,我们称为地址。 2.列表查找步骤 (1)在存储时,通过函数计算记录的地址,并按此地址存储该记录。 (2)当查找记录时,我们通过同样的函数计算记录的地址,并按此地址访问该记录。 技术既是一种存储方法,也是一种查找方法。 若我们现在要存储某家公司员工登记表,如果用手机号作为关键字,那么极有可能前7位都是相同的。那么我们选择后面的四位称为地址就是不错的选择。 如果关键字中有像18(3*6)、30(5*6)、42(7*6)等数字,它们的余数都为6,这就和78对应的下标位置冲突了。 4.处理冲突的方法 (1)开放定址法 所谓的开放定址法就是一旦发生了冲突,就去寻找下一个空的地址,只要列表足够大,空的地址总能找到,并将记录存入。

    2.1K40编辑于 2022-08-28
  • 来自专栏程序那些事

    单向函数

    单向函数 在介绍单向函数之前,我们先了解一下什么情况下需要使用到单向函数。 如果你需要从国外的网站上下载一个软件,但是因为种种原因,国外的网络太慢了,下载几个G的数据几乎是不可能的。 这个时候就需要单向函数了。一般来说网站会提供MD5或者SHA的值作为验证值。 单向函数有一个输入和输出。输入称为消息,输出称为值。 值的长度跟消息的长度无关,不论多少大小的长度的消息,都会计算出固定长度的值。 单向函数的性质 单向函数具有下面几个特性: 能够根据任意长度的消息计算出固定长度的值。 消息不同,值也不同。 这就意味着,如果仅仅是一点点的变动都会引起整个值的巨大变化。 因为值的大小是固定的,所以有可能会出现不同的消息产生相同值的情况。这种情况叫做碰撞。 当给定某条消息的值时,必须保证很难找到和该消息具有相同值的另一条消息。 单向函数必须具有单向性。所谓单向性是指无法通过值来反推出消息的性质。

    1.2K20发布于 2020-07-08
  • 来自专栏南桥谈编程

    哈希:哈希函数 | 哈希概念 | 哈希冲突 | 闭 | 开

    哈希也叫做,是一种映射,把值和值进行一对一或者一对多关联。 哈希表:使用哈希思想实现的数据结构。一般都是将值和存储位置建立映射关系。 解决哈希冲 闭:也叫开放定址法,当发生哈希冲突时,如果哈希表未被装满,说明在哈希表中必然还有空位置,那么可以把key存放到冲突位置中的“下一个” 空位置中去。 删除: 采用闭处理哈希冲突时,不能随便物理删除哈希表中已有的元素,若直接删除元素会影响其他元素的搜索。 其中:i =1,2,3…, H_0 是通过函数Hash(x)对元素的关键码 key 进行计算得到的位置,m是表的大小。 开法又叫链地址法(开链法),首先对关键码集合用函数计算地址,具有相同地址的关键码归于同一子集合,每一个子集合称为一个桶,各个桶中的元素通过一个单链表链接起来,各链表的头结点存储在哈希表中

    59910编辑于 2024-09-07
  • 来自专栏全栈程序员必看

    线性探测再

    在此称该函数H为哈函数或函数。按这种方法建立的表称为哈希表或列表。 =1,2,3,…, m-1,称线性探测再; 2.di=1^2, -1^2, 2^2,-2^2, 3^2, …, ±(k)^2,(k<=m/2)称二次探测再; 3.di=伪随机数序列,称伪随机探测再法:Hi=RHi(key), i=1,2,…,k. RHi均是不同的函数,即在同义词产生地址冲突时计算另一个函数地址,直到冲突不再发生,这种方法不易产生“聚集”,但增加了计算时间; 链地址法(拉链法):将所有关键字为同义词的记录存储在同一线性链表中 南京理工大学 2001 一、15 (1.5分)】 A.8 B.3 C.5 D.9 我的计算步骤如下: 15,38,61,84用哈希函数H(key)=key%11计算后得地址:4,5,6,7 49

    86830编辑于 2022-08-28
  • 来自专栏加密解密

    哈希函数算法

    一、哈希函数/算法文档 1.1、哈希函数介绍 哈希函数(Hash function),又称函数、算法,它是一种不可逆的信息摘要算法,具体实现就是把任意长度的输入信息通过哈希算法变成固定长度的输出信息 1.3、哈希函数的特点 哈希函数没有特定的公式,一般只要符合算法的要求即可,只要符合算法的要求都可以称之为哈希算法,以下为哈希函数的主要特点: 无论输入的消息有多长,计算出来的哈希值总是固定的; 通常情况下,不同的需求使用不同安全系数的算法,常见的安全哈希算法分类为:MD算法、SHA算法、MAC算法。 2.3、MAC算法 MAC(Message Authentication Code,消息认证码算法)算法是含有加密密钥的算法,它在MD和SHA算法特性的基础上加入了加密密钥(参考本在线工具的场景二) 因为MAC算法融合了密钥函数(keyed-Hash),通常我们也把MAC算法称为HMAC(Keyed-Hash Message Authentication Code)。

    1.4K40编辑于 2023-03-17
领券