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

做网站简约学校网站网站建设申请

做网站简约学校网站,网站建设申请,网络推广方案设计,杭州网站设计制作哈希表 是一种使用哈希函数组织数据的数据结构,它支持快速插入和搜索。 哈希表(又称散列表)的原理为:借助 哈希函数,将键映射到存储桶地址。更确切地说, 1.首先开辟一定长度的,具有连续物理地址…

哈希表 是一种使用哈希函数组织数据的数据结构,它支持快速插入和搜索。

哈希表(又称散列表)的原理为:借助 哈希函数,将键映射到存储桶地址。更确切地说,
1.首先开辟一定长度的,具有连续物理地址的桶数组;
2.当我们插入一个新的键时,哈希函数将决定该键应该分配到哪个桶中,并将该键存储在相应的桶中;
3.当我们想要搜索一个键时,哈希表将使用哈希函数来找到对应的桶,并在该桶中进行搜索。

负载因子 又叫装填因子,是哈希表的一个重要参数,它反映了哈希表的装满程度。
实际利用桶的个数 与 桶的总数 的比值,称为负载因子。

哈希函数

哈希函数是哈希表中最重要的组件,用于将键映射到特定的桶。我们使用 y = x % 5 作为散列函数,其中 x 是键值,y 是映射之后对应的桶的索引。

冲突解决

一般情况下,哈希函数会起到压缩键的地址空间的作用,设键的地址空间为 S,桶的地址空间为 T,则有 S≫T。
因此,经过映射之后,不同的数据会不可避免地分配到同一个桶中,这时便产生了冲突。

线性试探法

线性试探法属于开放定址法的一种,所谓线性试探法,就是当插入键 key 时,如果发现桶单元 bucket[hash(key)] 已经被占用,则向下线性寻找,直到找到可以使用的空桶。具体说来,经过第 i 次试探之后,桶单元应为:bucket[(hash(key)+i) mod M], i=1,2,3…

链地址法

解决冲突的另一种办法是将桶内产生冲突的键串联成一个链表。

再哈希法

再哈希法比较典型的应用是双重哈希法,即发生冲突时,通过使用另一个哈希函数来避免冲突。
然而,双重哈希法同样存在一些问题:
1.与线性试探法相比,双重哈希法会消耗较多的时间。
2.在双重哈希法中,删除会使问题变复杂,如果逻辑删除数量太多,则应重新构造哈希表。

公共溢出区法

顾名思义,公共溢出区法就是建立另一个哈希表 dict_overflow 作为公共溢出区,当发成冲突时则将该键保存在该哈希表中。

简单哈希集合

#define MAX_LEN 100000          // 初始化桶的数量class MyHashSet {
private:vector<int> set[MAX_LEN];   // 使用数组实现哈希集合/** 返回对应的桶的索引 */int getIndex(int key) {return key % MAX_LEN;}/** 在特定的桶中搜索键,如果该键不存在则返回 -1 */int getPos(int key, int index) {// 每个桶中包含一个列表,遍历所有桶中的元素来寻找特定的键for (int i = 0; i < set[index].size(); ++i) {if (set[index][i] == key) {return i;}}return -1;}
public:MyHashSet() {}void add(int key) {int index = getIndex(key);int pos = getPos(key, index);if (pos < 0) {// 如果键不存在,则添加set[index].push_back(key);}}void remove(int key) {int index = getIndex(key);int pos = getPos(key, index);if (pos >= 0) {// 如果键存在,则删除set[index].erase(set[index].begin() + pos);}}bool contains(int key) {int index = getIndex(key);int pos = getPos(key, index);return pos >= 0;}
};

简单哈希映射

#define MAX_LEN 100000            // 初始化桶的数量class MyHashMap {
private:vector<pair<int, int>> map[MAX_LEN];       // 使用数组实现哈希集合/** 返回指定桶的索引 */int getIndex(int key) {return key % MAX_LEN;}/** 在桶中搜索键,如果不存在则返回 -1 */int getPos(int key, int index) {// 每个桶包含一个数组,遍历桶中的所有元素来查找指定的 keyfor (int i = 0; i < map[index].size(); ++i) {if (map[index][i].first == key) {return i;}}return -1;}public:MyHashMap() {}/** value 始终为正 */void put(int key, int value) {int index = getIndex(key);int pos = getPos(key, index);if (pos < 0) {map[index].push_back(make_pair(key, value));} else {map[index][pos].second = value;}}/** 如果存在映射关系,则返回 value,否则返回 -1 */int get(int key) {int index = getIndex(key);int pos = getPos(key, index);if (pos < 0) {return -1;} else {return map[index][pos].second;}}/** 如果存在 key 的映射,则删除该映射关系 */void remove(int key) {int index = getIndex(key);int pos = getPos(key, index);if (pos >= 0) {map[index].erase(map[index].begin() + pos);}}
};
http://www.yayakq.cn/news/313329/

相关文章:

  • 智能网站建设模板售后wordpress网站页面打开很慢
  • 网站推广需要数据整改吗前端角度实现网站首页加载慢优化
  • 境外电商网站建设施工企业会计制度2022
  • 教我做网站广东省企业诚信建设促进会网站
  • 口碑营销网站自适应网站价格
  • 网站续费问题做兼职做网站的是什么
  • 湘icp备 网站建设 农业 湖南廊坊企业网站建设
  • 企业网站功能描述wordpress 自动采集发布
  • 哪家装修公司比较好的简述seo的优势
  • 济南建站优化wordpress 如何改中文
  • j建设网站备案流程重庆建设工程招标
  • 中国城乡建设部网站房贴文件建站快车官网
  • 做前端网站用什么软件写代码吗如何安装网站模板文件
  • 卫浴网站设计哪些网站页面简洁
  • wordpress 建网站 vpn南昌网站建设基本流程
  • 谁会在掏宝网上做网站跑腿小程序怎么制作
  • 苏州住房城乡建设部网站做视频网站要准备哪些资料
  • 怎样建个小公司的网站房源管理系统软件排名
  • 买网站做网站织梦可以做商城网站吗
  • 互联网设计公司网站云南电商网站建设
  • 襄樊大型网站建设邯郸招聘网最新招聘信息2023
  • 什么语言建手机网站IT周末做网站违反制度么
  • 深圳网站制作的公司排名wordpress最新文章代码
  • 外贸自建站 源码满城做网站电话
  • 延津县建设局网站搜索大全引擎入口
  • 民政 门户网站 建设新网网站备案流程
  • 南阳做网站的公司wordpress网站备份还原
  • 搜索引擎及门户网站介绍总结网站建设观点
  • 网站默认首页怎么设置哪里有学编程的培训班
  • 手机网站宽度网络新技术有哪些