当前位置: 首页 > wzjs >正文

学电商比较好的网站有哪些高端医疗网站开发

学电商比较好的网站有哪些,高端医疗网站开发,规则网站建设,网站建设佰首选金手指十三一、哈希表的概念 哈希表(hash table),又称散列表,是根据关键字直接进行访问的数据结构。哈希表建立了一种关键字和存储地址之间的直接映射关系,使得每一个关键字与结构中的唯一存储位置相对应。 将关键字映射成对应地…

一、哈希表的概念

        哈希表(hash table),又称散列表,是根据关键字直接进行访问的数据结构。哈希表建立了一种关键字和存储地址之间的直接映射关系,使得每一个关键字与结构中的唯一存储位置相对应。

将关键字映射成对应地址的函数就是哈希函数,也称散列函数,记作Hash(key)= Addr。 哈希函数可能会把两个或两个以上的不同关键字映射到同一地址,这种情况称为哈希冲突,也叫散列冲突。起冲突的不同关键字,称它们为同义词

由此可见, 设计一个优秀的哈希表,不仅需要设计一个好的哈希函数,也要能够处理哈希冲突。

二、哈希函数

1、直接定址法

        第一个案例中,统计字符串小写字符出现的次数所用的方法就是直接定址法。直接取关键字的某个线性函数值为散列地址,散列函数是hash(key)=a×key+b,其中a和b是常数。这种方式计算比较简单,适合关键字连续分部的情况。但是如果关键字分布不连续,空位较多,则会造成存储空间的浪费

2、除留余数法

        第二个案例所用的函数的方法就是除留余数法。假设哈希表的大小为M,那么通过key除以M的余数作为映射位置的下标,hash(key) = key % M。因此,这种方法的重点就是选好模数M。(一般M取不太接近2的整数次幂的一个质数)但是要注意,key有可能是负数,取模之后会变成负数,负数补正的操作只需要加上模数即可,但是正数加上模数会变大,所以统一再取一次模。最终就是(key % M + M)% M

三、处理哈希冲突

1、线性探测法

        从发生冲突的位置开始,依次向后探测,直到寻找到下一个没有存储数据的位置为止,如果走到哈希表尾,则回到哈希表头的位置。

#include <iostream>
#include <cstring>
using namespace std;const int N = 23, INF = 0x3f3f3f3f;
int h[N];void init()
{memset(h, 0x3f, sizeof h);
}int f(int x)
{int id = (x % N + N) % N;while (h[id] != INF && h[id] != x){id++;if (id == N)id = 0;}return id;
}void insert(int x)
{int idx = f(x);h[idx] = x;
}bool find(int x)
{int id = f(x);return h[id] == x;
}

2、链地址法 

        链地址法中所有的数据不再直接存储在哈希表中,哈希表中存储一个指针,没有数据映射这个位置时,这个指针为空,有多个数据映射到这个位置时,我们把这些冲突的数据连接成一个链表,挂在哈希表这个位置下面。实现方式与树的链式前向星一模一样。

#include <iostream>
using namespace std;const int N = 23;
int h[N];
int e[N], ne[N];
int id;int f(int x)
{return (x % N + N) % N;
}void insert(int x)
{int idx = f(x);//把x头插到idx所在的链表中id++;e[id] = x;ne[id] = h[idx];h[idx] = id;
}bool find(int x)
{int idx = f(x);for (int i = h[idx];i;i = ne[i]){if (e[i] == x)return true;}return false;
}

四、unordered_set & unordered_map

        C++中的STL为我们提供了两种哈希表——unordered_set 和 unordered_map。set和unordered_set的区别就是,前者是用红黑树实现的,后者是用哈希表实现的。前者是有序的,后者是无序的。使用方式和上一章的set和map是完全一样的,这里就不做代码实现了。

http://www.dtcms.com/wzjs/548198.html

相关文章:

  • 如何检测网站被搜索引擎惩罚了手机百度官网首页
  • 网站插件 wordpress哈尔滨建站软件
  • 中山网站优化排名郑州免费建站
  • 网站建设发朋友圈的图片盐城做网站价格
  • 响应式网站的优缺点网站建设公司的市场开拓方案
  • 万家灯火网站建设网站项目开发流程及规范
  • 唯品会网站建设方案如何进行品牌宣传与推广
  • 福建省环保厅网站建设项目验收公司官网制作需要多少钱一个
  • 开工作室做网站怎样找资源企业管理培训课程网课免费
  • dz网站收款即时到账怎么做的优化方案怎么写
  • 广东省建设信息网站东莞主页网站制作
  • 外贸式响应式网站自己做的网站怎样链接数据库
  • 我做的网站怎么是危险网站网站seo策划方案案例分析
  • 网站界面用什么做Wordpress 1688 采集
  • 好的网站设计培训机构建培网
  • 制作企业网站价格网站建设海报素材图片
  • 上海网站建设哪家技术好北京代做网站
  • 视频网站怎么做排名工程公司简介范文
  • 二 网站建设的重要性在线制作图片加文字的软件
  • 做商业地产的网站优化大师百科
  • 如何建设一个自己+的网站首页北京师范大学学风建设专题网站
  • 潍坊地区网站制作网站运维合同
  • 云服务器建网站wordpress 火箭
  • 国外二手表网站昆山网站制作昆山网站建设
  • 免费网站在哪里申请表龙岗教育网官网
  • 深圳网站建设前十名小程序开发用什么语言
  • 做网站注意的问题品牌设计流程
  • 精简网站模板深圳定制网站建设
  • 聊城网站建设服务好网站建设的广告投入
  • 网站后台的制作公司想做网络推广贵不