美文网首页数据结构学习
散列储存(hash储存)的理解

散列储存(hash储存)的理解

作者: charlesLaw | 来源:发表于2016-01-20 13:27 被阅读191次

先来了解一下Hash的基本思路:

设要存储对象的个数为num, 那么我们就用len个内存单元来存储它们(len>=num); 以每个对象ki的关键字为自变量,用一个函数h(ki)来映射出ki的内存地址,也就是ki的下标,将ki对象的元素内容全部存入这个地址中就行了。这个就是Hash的基本思路。
为什么要用一个函数来映射出它们的地址单元呢?
假设现在我要存储4个元素 13 7 14 11
显然,我们可以用数组来存。也就是:a[1] = 13; a[2] = 7; a[3] = 14; a[4] = 11;
当然,我们也可以用Hash来存。下面给出一个简单的Hash存储
先来确定那个函数。我们就用h(ki) = ki%5;
对于第一个元素 h(13) = 13%5 = 3; 也就是说13的下标为3;即Hash[3] = 13;
对于第二个元素 h(7) = 7 % 5 = 2; 也就是说7的下标为2; 即Hash[2] = 7;
同理,Hash[4] = 14; Hash[1] = 11;
现在我要你查找11这个元素是否存在。你会怎么做呢?当然,对于数组来说,那是相当的简单,一个for循环就可以了。
也就是说我们要找4次。
下面我们来用Hash找一下。
首先,我们将要找的元素11代入刚才的函数中来映射出它所在的地址单元。也就是h(11) = 11%5 = 1了。下面我们来比较一下Hash[1]?=11, 这个问题就很简单了。也就是说我们就找了1次。这个就是Hash的妙处了,通过制定一个规则(函数)来映射出它的地址,数据也就能通过这个规则去找到它的内存地址了。

相关文章

  • 散列储存(hash储存)的理解

    先来了解一下Hash的基本思路: 设要存储对象的个数为num, 那么我们就用len个内存单元来存储它们(len>=...

  • 矩阵和数据

    1.matrix()函数创建矩阵,矩阵在R中是按列储存。即先储存第一列,再储存第二列,依次类推 2.apply()...

  • 散列表和素数

    理解自:邓俊辉老师 《数据结构:散列》 -以蝉为师 我们假设有两个散列hash_a和hash_b,表a的长度M =...

  • Java 1.8 HashMap

    HashMap 是由数组+链表的形式进行储存数据的 1. 储存数据的内部类 Node hash: key的has...

  • IOS 逆向开发(二)密码学 HASH

    1. HASH算法简介 1.1 HASH是什么? Hash算法(也叫散列算法) Hash,一般翻译做“散列”,也有...

  • 散列 Hash

    一、什么是散列? 散列 Hash是和顺序、链接和索引一样,是存储集合或者线性表的一种方法。 散列的基本思想是:以集...

  • App安全与加密下

    Hash (散列函数) 1.Hash定义 Hash:把任意长度的输入,通过散列算法,变换成固定长度的输出,该输出就...

  • 加密函数,加密手段。

    密码散列函数: 密码散列函数(英语:Cryptographic hash function),又译为加密散列函数、...

  • Map中的一些算法与数据结构简析

    一、Hash算法 1、 什么是Hash Hash散列,将任一长度的输入,通过一种算法,变成固定长度的输出。可以理解...

  • Redis5数据类型3-Hash

    1. Hash散列 是指Redis中存储的value值是Hash散列类型的。而Hash也有自己的数据结构: 它是由...

网友评论

    本文标题:散列储存(hash储存)的理解

    本文链接:https://www.haomeiwen.com/subject/fwklkttx.html