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

做非经营网站需要营业执照搜索引擎seo优化平台

做非经营网站需要营业执照,搜索引擎seo优化平台,开发公司采购部工作流程,东莞建网站服务全文目录 概念哈希冲突及原因解决哈希冲突的方法闭散列线性探测二次探测扩容 开散列扩容 哈希的应用位图布隆过滤器 概念 通过映射关系将关键字映射到存储位置,并实现增删改查操作。 通过上面的方法构造出来的结构就叫哈希表(散列表)&#x…

全文目录

  • 概念
  • 哈希冲突及原因
  • 解决哈希冲突的方法
    • 闭散列
      • 线性探测
      • 二次探测
      • 扩容
    • 开散列
      • 扩容
  • 哈希的应用
    • 位图
    • 布隆过滤器

概念

通过映射关系将关键字映射到存储位置,并实现增删改查操作。

在这里插入图片描述

通过上面的方法构造出来的结构就叫哈希表(散列表),其中的映射关系叫做哈希函数

哈希冲突及原因

不同的关键字映射到同一个位置称为哈希冲突

原因:

哈希函数设计得不够合理

哈希函数设计原则:

  • 哈希函数的定义域包括所有关键码,散列表的空间位 n,其值域为 [ 0 , m − 1 ] [0,m - 1] [0,m1]
  • 计算出来的地址均匀分布在整个散列表中
  • 比较简单

其他类型哈希:

哈希函数需要将关键码进行取模操作,这就表示了当其他类型哈希时需要先将关键字转换为整型 —— 可以通过仿函数进行转换。

解决哈希冲突的方法

解决哈希冲突两种常见的方法是:闭散列和开散列

闭散列

闭散列:也叫开放定址法,当发生哈希冲突时,如果哈希表未被装满,说明在哈希表中必然还有空位置,那么可以把key存放到冲突位置中的“下一个” 空位置中去。

寻找“下一个”空位置的方法:线性探测和二次探测

线性探测

从发生冲突的位置开始,依次向后探测,直到寻找到下一个空位置为止。

在这里插入图片描述

缺点:

冲突连在一起容易发生数据堆积,不同的关键字占用了可利用的空位置,使得同一个效率下降,影响效率

二次探测

线性探测造成数据堆积的原因是寻找空位置的方式,为了避免数据堆积,二次探测寻找下一个位置的方式为:

H i = ( H 0 + i 2 ) % m H_i = (H_0 + i^2 ) \% m Hi=(H0+i2)%m, 或者: H i = ( H 0 − i 2 ) % m H_i = (H_0 - i^2 ) \% m Hi=(H0i2)%m。其中: i = 1 , 2 , 3 … i = 1,2,3… i=1,2,3 H 0 H_0 H0 是通过散列函数 H a s h ( x ) Hash(x) Hash(x) 对元素的关键码 k e y key key 进行计算得到的位置, m m m 是表的大小。

在这里插入图片描述

扩容

当哈希表的载荷因子达到一定大是进行扩容

在这里插入图片描述

开散列

开散列法又叫链地址法(开链法),将相同地址的关键字分为一个集合称为桶,通过单链表将桶中的元素链接起来。

在这里插入图片描述
在这里插入图片描述

扩容

随着插入的增加,冲突的可能性越来越大即一个桶中节点越来越多,影响哈希表的性能。开散列最好的情况是每个哈希桶都只有一个节点,所以当 元素个数 = = 桶的个数 元素个数 == 桶的个数 元素个数==桶的个数 时进行扩容较为合理

哈希的应用

位图

用一个比特位来存放某种状态,用来快速判断某个数据在不在。

模拟实现:

template<size_t N = 100>
class bitset
{
public:bitset(size_t n = N){_bit.resize(N / 8 + 1, 0);}bitset& set(size_t x, bool val = true){size_t i = x / 8;size_t j = x % 8;if (val){_bit[i] |= 1 << j;}else{_bit[i] &= ~(1 << j);}return *this;}bitset& set(){vector<char> tmp(N / 8 + 1, 1);_bit.swap(tmp);return *this;}bitset& reset(){vector<char> tmp(N / 8 + 1, 0);_bit.swap(tmp);return *this;}bitset& reset(size_t x){size_t i = x / 8;size_t j = x % 8;_bit[i] &= ~(1 << j);return *this;}bool test(size_t x) const{size_t i = x / 8;size_t j = x % 8;return _bit[i] & (1 << j);}private:vector<char> _bit;size_t _size;
};

缺点:

一般只能处理整型

布隆过滤器

用来快速检索数据是否存在,弥补位图只能处理整型的缺憾。

原理:

通过多个哈希函数,将一个数据映射到位图结构中。

但是可能对存在的情况存在一定的误判,误判概率取决于哈希函数的个数和空间的大小:参考文档

http://www.khdw.cn/news/19579.html

相关文章:

  • 日照园林建设发展有限公司网站免费关键词优化排名软件
  • 免费做长图的网站微信朋友圈推广文案
  • 霍州做网站深圳网络营销模式
  • 自己做的网站怎么放到外网上线上网络推广怎么做
  • 中山市做网站的公司广州seo招聘网
  • 急招二级建造师长沙搜索排名优化公司
  • 自己想做一个网站怎么做的腾讯企点qq
  • 北京市门头沟有没有做网站的新网站如何推广
  • 服务器建设网站品牌推广公司
  • 兰州网站的优化合肥百度快速排名优化
  • dw网站建设关键词在线试听免费
  • 追设计网站今天国际新闻大事
  • 我做的网站不知道网站怎么办搜索引擎关键词的工具
  • 电子商务网站建设与维护的教学建网站一般多少钱
  • 动态网站开发 用什么模板语言企业营销推广方案
  • 用word文档做网站腾讯云域名注册官网
  • 网站项目策划书模板seo推广公司有哪些
  • 做网站用jsp还是html微信搜一搜seo
  • 网站上传视频怎么做口碑营销案例有哪些
  • 黄山网站建设公司上海网络营销
  • 郑志平爱站网创始人宣传页面怎么制作
  • 苏州高端网站设计企业怎样做好销售和客户交流
  • dw网站制作流程发表文章的平台有哪些
  • wordpress begin教程seo权重查询
  • 北京最大的网站建设有限公司公司企业员工培训
  • 齐博企业网站推广公司有哪些公司
  • wordpress需要翻墙吗关键词排名优化工具有用吗
  • 岳阳企业网站定制开发成品网站源码的优化技巧
  • 深圳做app网站制作seo怎么发外链的
  • 如何查网站有无备案举例网络营销的例子