(一)处理冲突的方法——开放定址法

  • 所谓开放定址法,是指可存放新表项的空闲地址既向它的同义词表项开放,又向它的非同义词表项开放。其数学递推公式为:

1. 线性探测法

(1)插入操作










(2)查找操作




(3)删除操作


❗❗❗❗❗❗

  • 注意:采用“开放定址法”时,删除结点不能简单地将被删结点的空间置为空,否则将截断在它之后填入散列表的同义词结点的查找路径,可以做一个“删除标记”,进行逻辑删除

❗❗❗❗❗❗





  • 线性探测法很容易造成同义词、非同义词的“聚集(堆积)”现象,严重影响查找效率
  • 产生原因——冲突后再探测一定是放在某个连续的位置

2. 平方探测法

(1)插入操作


  • 注意负数的模运算,(-3)%27 = 24,而不是3
    《数论》中模运算的规则:a MOD m == (a+km) MOD m , 其中,k为任意整数

(2)查找操作

  • 平方探测法:比起线性探测法更不易产生“聚集(堆积)”问题

3. 伪随机序列法

(二)处理冲突的方法——再散列法

散列表的开放定址法以及再散列法(C语言)相关推荐

  1. 散列表(开放定址法)

    散列表(开放定址法) 1.线性探测法 将具体的值输入到哈希函数中,映射出的具体的哈希表中的下标索引.当下标索引冲突时. 离散链表法:将重复了的值用链表的方式挂在对应索引的链表下. 线性探测法:一个位置 ...

  2. 散列表相关题目(线性探测再散列法)

    散列表相关题目(线性探测再散列法) 一.题目 将关键字序列(7.8.30.11.18.9.14)散列存储到散列表中.散列表的存储空间是一个下标从0开始的一维数组,散列函数为H(key)=(key×3) ...

  3. 哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之上——原理与设计

    哈希表(Hash table,也叫散列表),是根据键(Key)而直接访问数据在内存中的储存位置(又叫做存储桶,Buckets)的数据结构.也就是说,它通过计算一个关于键值的函数(哈希函数,Hash f ...

  4. 哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之下——设计键

    在很多应用中,我们会发现某种映射关系(模式),但它并不是简单一 一对应的.这时,我们就要从键 key 入手,通过设计合适的键,建立映射关系.leetbook的这个章节总结了一些常见的键,以供参考. 4 ...

  5. 哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之中——实际应用

    上一节介绍了哈希表的原理与设计方法,这一节则直接python中现有的哈希表类型:哈希集合 set(集合)和哈希映射 dict(字典)来解决实际应用(刷题). 零.概念 在介绍实际应用之前,有一个概念我 ...

  6. Python与数据结构[4] - 散列表[1] - 分离链接法的 Python 实现

    分离链接法 / Separate Chain Hashing 前面完成了一个基本散列表的实现,但是还存在一个问题,当散列表插入元素冲突时,散列表将返回异常,这一问题的解决方式之一为使用链表进行元素的存 ...

  7. 散列表(哈希表)(散列函数构造、处理冲突、查找)

    本文转载自: [1]https://blog.csdn.net/qq_22238021/article/details/78258605 [2]https://blog.csdn.net/duan19 ...

  8. 哈希表(散列表)知识点概述

    引言 在查找数据过程中,有很多种方法,但是大部分都是通过数据间的比较进行的,有没有一种方法可以直接通过关键字得到要查找的数据的位置的方法呢?这就需要用到一种新的查找方法,散列查找法: 基本思想 记录存 ...

  9. 【数据结构-查找】3.散列表详解

    散列表的一些基本概念 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度 ...

  10. 数据结构:哈希表(散列表)基础

    哈希表(散列表)基础 引入哈希表 什么是哈西表: 一种具有相同特性的数据元素的集合,每个元素具有唯一标识自己的关键字. 基本原理: 说明: 顺序查找.二分查找或者二叉树的查找是基于待查关键字与表中元素 ...

最新文章

  1. matlab 数字识别_在MATLAB中利用神经网络进行分类
  2. IP、TCP和DNS与HTTP的密切关系
  3. 如何在 Dapper.NET 中使用事务?
  4. 制作自定义工作流(WWF)设计器
  5. 这就是华为Mate 30 Pro真机了,价格或许要高攀不起了?
  6. BundleLoader:帮你无缝加载自定义Bundle里的资源文件
  7. **Java有哪些悲观锁的实现_Redis 分布式锁的正确实现方式(Java 版)
  8. l如何更新linux内核,WSL更新Linux内核版本
  9. php转java还是python_我是应该继续学习php还是转JAVA Go Python?
  10. Atitit 全屏模式的cs桌面客户端软件gui h5解决方案 Kiosk模式
  11. 牛掰!某厂风控大佬整理的一套黑客学习思维导图及教程!
  12. 最新传奇游戏公司网站模板源码+带手机端/易优CMS内核
  13. html网页如何将文字排版,【html】文字排版
  14. 我来自江湖修改器|我来自江湖修改器3dm下载 v0.1二十四项
  15. 腾讯应用宝市场的app 安全评估报告怎么写
  16. 上海小伙三次成功创业,资产达上十亿被称为“创业神童”
  17. reactos 0.0.21 编译
  18. 基于Java毕业设计政府采购线上招投标平台源码+系统+mysql+lw文档+部署软件
  19. RTL8197F/RTL8812F WiFi设置为WPA3加密手机提示拒绝连接问题解决方案
  20. jQuery mobile插件基础知识笔记

热门文章

  1. 三菱PLC功能指令详解
  2. 经纬度WGS84地理坐标系转换成CGCS2000坐标系步骤
  3. 用什么软件可以编辑pdf文件
  4. 安全事件应急响应工具箱
  5. 【直通车介绍】拼多多商家如何开直通车,如何开好直通车?
  6. 游戏测试和软件测试有什么区别?
  7. 分库分表中间件 sharding
  8. 各种单点登录方案调研
  9. at+cipstart返回state:tcp close解决方案 SIM868模块使用
  10. element ui 前台模板_简单了解Vue + ElementUI后台管理模板