c/c++ hash表 (哈希表、字典表)

2023-05-16

1: 表: 存储数据 key –> value;

这里写图片描述


2: 表存储数据结构的困难:
怎么查找? 一个一个key去比较去查找?==效率不高

这里写图片描述


**3: Hash算法加快查找;
将字符串的key,转成整数,使用整数找到对应的value;**

Hash算法将字符串转成整数,同样的Hash值得 key:value会放到一个集合里面,由于Hash能使得不同的字符串尽量有不同的整数值(仍然有重复);
将海量的数据,按照HASH值分成不同的集合,先找集合,再找key–>value,大大提高效率;

这里写图片描述


Hash表设计

1: key, value节点:
struct hash_node {
char* key;
void* node;
struct hash_node* next;
};

2: hash算法: 选取一种HASH算法;
3: 有限的集合数目, 定义一个集合数目,每个集合的元素用链表连接;
4: 对用户开放的hash表接口;
struct hash_table* creator_hash_table(集合的数目);
void destroy_hash_table(struct hash_table*);
void* hash_find(table, char* key);
hash_delete(table, char* key);
hash_insert(table, char*key, void* value); // 直接插入,不判断是否有key重复;
hash_set(table, char* key, void* value); // 如果key存在就覆盖,如果不存在返回;


  • 身份证(key):数据信息(value),如果我们有10000个学生,查找一个学生的话,很费劲;
  • 如果说有一个办法能均匀的将10000个人分成n个集合,(N100*100)我们有一种办法能快速的找到key,所对应的集合,那么就能很快的在集合里面找出所对应的value;
  • 怎么根据key来分集合;
  • 怎么分能够相对比较均匀;
  • 采用Hash算法
    • 1:将一个字符串变成一个整数 %N规模(0,N-1)的集合序号里面
    • 整数 %N = 集合序列号,[0,n-1],用数组来表示每个集合;
    • 2:对于不同的字符串,尽可能的生成不同的Key;
      • Hash散列,要散得足够均匀;
      • “hello”–>3;
      • “helmm” –>7;
      • 随机的字符串样本,能均匀的分布出来,分散开来;
    • 主流的Hash算法;
      • –》经典哈希算法

创建Hash结构

这里写图片描述

这里写图片描述


创建hash对象

这里写图片描述


这里写图片描述


引用mysql经典算法函数

这里写图片描述


增/插入数据

这里写图片描述


这里写图片描述


删除表

这里写图片描述

这里写图片描述


删除hash对象

这里写图片描述


这里写图片描述


修改数据

这里写图片描述

这里写图片描述


查询数据

这里写图片描述

这里写图片描述


这里写图片描述

总结

1: 理解HASH表的原理,为什么能实现基于名字快速查找;
2: 理解HASH算法;
3: 编写HASH表;


–>源码

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

c/c++ hash表 (哈希表、字典表) 的相关文章

  • python 两个list 求交集,并集,差集

    项目github地址 xff1a bitcarmanlee easy algorithm interview and practice 经常有同学私信或留言询问相关问题 xff0c V号bitcarmanlee github上star的同学
  • stm32 esp8266 ota-快速搭建web服务器之docker安装openresty

    stm32 esp8266 ota系列文章 xff1a stm32 esp8266 ota 快速搭建web服务器之docker安装openresty stm32 esp8266 ota升级 tcp模拟http stm32 esp8266 o
  • csapp-01:从程序员的角度去了解计算机系统的工作原理

    写在开头 xff1a 本人非科班 xff0c 之前没读过 xff0c 只听说是本好书 xff0c 硬着头皮花了四天时间通读了一遍 xff0c 书上画得密密麻麻的 xff0c 尤其是在虚拟内存这一章到处写满注解 xff0c 只能说这本书的确不
  • STM32F10x启动文件详解

    本文为使用汇编开发STM32系列文章之 启动文件详解篇 xff0c 全部文章目录点此跳转 本文不会像其他文章一样只是简单的说一下启动文件的每个部分是什么 xff0c 说了很多却又像没说一样 本文将对启动文件中的每句话的作用及其如此编写的原因
  • docker 通过python方式调用YOLO镜像

    这篇blog记录下配置的yolov3的docker环境 xff08 cuda9 43 cudnn7 43 ubuntu16 04 xff09 可以pull我的镜像 已经pull在docker hub上了 docker pull cheney
  • IMAXB6充电器使用教程

    视频地址 xff1a http blog sina com cn s blog 130ac99cd0102vegw html 做个笔记 B6充电器介绍 xff1a B6充电器是一台多功能充电器 xff0c 它支持双输入 xff0c 是运用内
  • STM32寄存器_GPIO操作

    提示 xff1a 文章写完后 xff0c 目录可以自动生成 xff0c 如何生成可参考右边的帮助文档 文章目录 前言一 模式配置寄存器CRL和CRH二 端口输入数据寄存器 GPIOx IDR x 61 A E 三 端口输出数据寄存器 GPI
  • 相机几何学——相机投影矩阵( Camera Projection Matrix)

    相机投影矩阵为P xff0c 是MTMC任务中每个标定好的摄像机所配备的参数 总是忘记关于它的基本性质 xff0c 现在写在这里 1 P矩阵的维度是3 4 2 相机成像过程可以描述为x 61 PX xff0c 其中X是一个4 1的向量 xf
  • ROS消息传递——std_msgs

    转自 xff1a ROS学习 xff08 四 xff09 ROS消息传递 std msgs 经常看到 xff1a from std msgs msg import String xff0c 这 std msgs 究竟是什么东西 xff0c
  • 多目录工程的CmakeLists.txt编写(自动添加多目录下的文件)

    实现类似于vs中工程的CMakeLists txt的编写 功能为main cpp调用hello cpp 的hello 函数 xff0c world cpp的world 函数 使用自动添加多目录下的文件 xff0c 用add library方
  • 最容易理解的对卷积(convolution)的解释

    项目github地址 xff1a bitcarmanlee easy algorithm interview and practice 经常有同学私信或留言询问相关问题 xff0c V号bitcarmanlee github上star的同学
  • 使用STM32F103做CAN的收发通信

    下面也是搭建嵌入式系统所必须的一个部分 参考网站 xff1a https www cnblogs com craigtao p 3645148 html https blog csdn net qq 29413829 article det
  • 解决matlab遇到的“错误使用 mex未找到支持的编译器或 SDK。”

    解决matlab遇到的 错误使用 mex未找到支持的编译器或 SDK 因为coco数据集转pascal数据集需要用到matlab的以下代码 xff1a span class token function mex span span clas
  • STM32开发 数据包环形队列

    目录 前言一 构建环形队列结构体二 队列初始化三 读写数据1 队列满判断2 队列空判断3 队列写入数据4 队列读取数据 四 实际使用 前言 环形队列的理论知识网上有很多文章 xff0c 这里我就仅通过代码分享一下使用经验 xff0c 在我的
  • 静态链接库lib和动态链接库ddl的区别和联系

    静态链接库lib和动态链接库ddl的区别 联系 xff1a 都是在链接阶段使用的 区别 xff1a 不同的是静态链接库中的代码会直接放到exe中 xff0c 而动态链接库在使用时才会被加载到这个exe执行的内存空间 xff0c 所以使用静态
  • 单片机与上位机的串行通信

    写在前面 这篇博客主要记录下单片机是如何通过TXD RXD与上位机进行数据交换的 先介绍下51单片机中与串口通信有关的各种寄存器 首先 xff0c 上位机如果要发送数据给单片机 xff0c 单片机接收到数据之后 xff0c 会存入到SBUF
  • 【C++知识】关于迭代器失效的几种情况

    前言 关于面试时有被问到过这类问题 xff0c 当时由于只一知半解 xff0c 回答的不是特别好 xff0c 所以今天自己特意来实验一下 希望能帮助大家有同样疑惑的人解答疑惑 xff01 目录 关于迭代器失效的几种情况 1 序列式容器迭代器
  • Yolov3+C+++opencv+VS2015成功检测

    nbsp 前言 nbsp nbsp nbsp 最近在用yolov3进行目标检测 也有一个多星期了 想把最近做出的一些成果记录下来 供大家参考下 我的运行环境是C opencv VS2015 yolov3 下面将简单介绍下yolo的一些思想
  • simulink之S函数

    s函数是system Function的简称 xff0c 用它来写自己的simulink模块 xff08 够简单吧 xff0c xff0c 详细的概念介绍大伙看帮助吧 xff09 可以用matlab C C 43 43 Fortran Ad
  • win10解决未安装任何音频输出设备

    最近刚刚更新了一下win10系统 xff0c 开始啥问题没有 xff0c 晚上睡觉关机后 xff0c 第二天开机 xff0c 小喇叭处有一个红叉 xff0c 显示未安装任何音频输出设备 查看了微软的官网以及百度了很多解决方法 xff0c 电

随机推荐

  • Quadcopter控制

    1 问题描述 四旋翼飞行器对角线上的两个电机旋转方向相同 xff0c 另一对与之旋转方向相反 这是使推力 xff0c 滚转 xff0c 俯仰 xff0c 偏航相互独立控制的必要条件 这可以使我们命令其中的一个动作而不影响其他动作 实际上 x
  • 入门级都能看懂的softmax详解

    项目github地址 xff1a bitcarmanlee easy algorithm interview and practice 经常有同学私信或留言询问相关问题 xff0c V号bitcarmanlee github上star的同学
  • LQR制导

    LQR制导 引言 在ardupilot中固定翼飞机横航向位置控制 xff08 制导律 xff09 采用L1制导律 xff0c 最近想将一些其他的控制理论用于ardupilot代码中 xff0c 通过ardupilot论坛 xff0c 看到已
  • 2022年度总结

    年度总结 参加工作的第一年很快就过去了 xff0c 从四月份离校到公司 xff0c 直到农历腊月27回家 xff0c 工作了9个月的时间 xff0c 总的来说工作和学习的差别还是很大的 xff0c 从学生到社畜的转换还是花了一段时间的 接下
  • HTTP基本认证

    在HTTP中 xff0c 基本认证 xff08 英语 xff1a Basic access authentication xff09 是允许http用户代理 xff08 如 xff1a 网页浏览器 xff09 在请求时 xff0c 提供 用
  • c# 设置代理服务器发送http请求

    span class token keyword using span span class token namespace System span span class token punctuation span span class
  • Blaze:高性能C++数学库

    Blaze xff1a 高性能C 43 43 数学库 本文译自 xff1a Blaze A high performance C 43 43 math library Blaze是一个用于密集和稀疏算法的开源 高性能 C 43 43 数学库
  • c/c++编译:使用CMAKE进行跨平台开发

    前言 本文介绍跨平台cmake的编写 xff0c 主要是linux和windows用cmake对项目的编译 这是一个通用模板 xff0c 能够应用到更加复杂的项目中 xff0c 项目例子用https blog csdn net qq 364
  • 对于应用层HTTP协议的学习

    lt start gt 在TCP IP协议栈中 xff0c HTTP协议处于应用层 xff0c 它在最顶层进行数据报转发给应用进程 xff0c 它是最靠近用户的那一层 它的默认端口号为80 HTTP协议是基于请求响应的协议 xff0c 那么
  • 编程开发环境搭建

    全部目录 下载 amp 安装官方下载Vs2019其它历史 版本下载 开始使用安装C 43 43 的工作负载 xff08 环境 xff09 打开vs后有这些模板创建出一个控制台应用程序更多参考文档 使用手册c 43 43 参考手册Visual
  • c++创建第一个控制台程序

    目录 创建控制台应用程序打印出Hello World 空项目创建vs自带打印的创建桌面向导 自定义创建 了解代码 抛转引玉减少为什么 什么是 include 它是预处理指令什么是iostream 它是c 43 43 标准库头件 编写前的了解
  • python3-操作SQLite、创建表、添加数据、查询数据

    SQLlte数据类型 SQLite能保存什么样的数据类型 可以保存空值 整数 浮点数 字符串和blob 什么是blob xff1f xff1f 是二进制大对象 例如图片 音乐 zip文件 什么是游标 游标是在数据库中用来移动和执行查询的对象
  • 初学者都能看懂的95%置信区间

    项目github地址 xff1a bitcarmanlee easy algorithm interview and practice 经常有同学私信或留言询问相关问题 xff0c V号bitcarmanlee github上star的同学
  • c# WindowForm练习项目主窗体设计

    窗体分割器 SpliContainer分割器 在项目主窗体分割成左右俩部分 设置边框线属性 MonthCalendar月历控件 添加程序所需要的按钮 退出 修改密码 添加会员 按钮 固定好左边的容器 组件 ImageList 按钮太多添加图
  • C#-WinForm班级下拉框数据绑定

    前台展示 后台方法 span class hljs keyword using span System span class hljs keyword using span System Collections Generic span c
  • C#--WinForm项目主窗体设计

    主窗体基本设置 大小 颜色 去边框 出现的位置 Panel控件 背景图 颜色 布局 xff1a Label标签 文本 字体 背景颜色 布局 按钮 布局 文本 字体颜色 背景色 底部panel 绑定控件边框 颜色 用label标签导入图标 S
  • C# -- 实现WinForm程序的密码修改

    修改窗体程序密码的示例 实现分析 前台弹出修改窗体 编写后台方法 xff0c 调用通用数据访问类Update方法 数据验证 xff0c 判断原密码是否与旧密码符合 xff0c 俩次输入的新密码是否一致 更新程序全局变量 前台弹出修改窗体 编
  • C#--WinForm--表格数据控件DataGridView--绑定模式

    官方文档 DataGridView控件提供了一种强大而灵活的以表格形式显示数据的方式 用户可以使用DataGridView控件来显示少量数据的只读视图 xff0c 也可以对其进行缩放以显示特大数据集的可编辑视图 扩展DataGridView
  • ASP.NET--网站配置、发布与部署

    网站发布前的配置信息 配置文件下载 网站发布的基本步骤 写好的项目 在本机上发布 打开目录查看 xff1a 部署网站 安装IIs 打开控制面板 程序和功能 启用或关闭Windows功能 安装后 返回控制面板 管理工具 双击打开 xff1a
  • c/c++ hash表 (哈希表、字典表)

    表 1 表 存储数据 key gt value 2 表存储数据结构的困难 怎么查找 一个一个key去比较去查找 xff1f 61 61 效率不高 3 Hash算法加快查找 将字符串的key 转成整数 使用整数找到对应的value Hash算