哈希表(hashtable)的数据插入、查找和遍历

news2024/10/5 17:20:39

文章目录

  • 前言
  • 一、哈希
  • 二、哈希的具体实现
    • 2.1 准备工作
    • 2.2 插入数据
    • 2.3 输出哈希表
    • 2.4 在哈希表中寻找数据
    • 2.5 销毁哈希表
  • 三、 哈希表的调用
  • 总结


前言

本期主要和大家介绍一下哈希算法,这里主要给出哈希算法的实现方法;


一、哈希

hash是一种算法:
哈希冲突(哈希碰撞):不同的数据通过哈希算法映射出来的键值相同
解决办法:通过在键值相同的位置加入链表存储数据

二、哈希的具体实现

2.1 准备工作

(1)宏定义10个(表示指针数组的容量为10)-------指针数组(一个数组中的元素都是指针);
(2)定义链表节点的结构体;
(3)定义一个容量为MAXLEN的指针数组;

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAXLEN		10

typedef struct node
{
	int Data;
	struct node *pNext;
}LinkNode;

LinkNode *HashTable[MAXLEN];

2.2 插入数据

由于指针数组中最终存放的10个键值链表的首地址,所以应该定义二级指针,以此修改指针数组中指针所指向的地址,其实修改的是地址的地址;销毁板门认真看注释哦!

int InsertHashTable(int TmpData)
{
	int index = 0;
	LinkNode **ppTmp = NULL;			//指向链表中第一个元素
	LinkNode *pNode = NULL;

	index = TmpData % MAXLEN;			//以每个数据的个位数来作为键值

	for (ppTmp = &HashTable[index]; *ppTmp != NULL && TmpData > (*ppTmp)->Data; ppTmp = &(*ppTmp)->pNext)
	{

	}			//找到合适的位置(按照元素大小排列,判断条件中如果是空跳出循环,如果要插入的数据大于当前数据,那么也跳出循环,接下来只需要在当前数据的后面插入数据即可),准备插入数据
	
	pNode = malloc(sizeof(LinkNode));	//为即将插入的数据创建链表节点
	if (NULL == pNode)
	{
		perror("fail to malloc");
		return -1;
	}

	pNode->Data = TmpData;				//将数据存入链表节点
	pNode->pNext = *ppTmp;				//将插入的数据节点指向原来前一个节点的下一个
	*ppTmp = pNode;						//将原来前一个节点指向目前插入的节点
	
	return 0;
}

2.3 输出哈希表

这里重点解释一下这句代码: ppTmp = &(*ppTmp)->pNext
(1)ppTmp是一个二级指针。*ppTmp 表示LinkNode *类型,也就是节点指针类型
(2)(*ppTmp)->pNext表示指向下一个节点;
(3)&(ppTmp)->pNext,这里的&是因为ppTmp是二级指针类型,为了使得类型匹配;这里也可以换成ppTmp = (*ppTmp)->pNext;但是为了代码整齐,前面是从ppTmp开始的,所以后面也使用ppTmp;

int ShowHashTable(void)
{
	int i = 0;
	LinkNode **ppTmp = NULL;

	for (i = 0; i < MAXLEN; ++i)
	{
		printf("%2d:", i);
		for (ppTmp = &HashTable[i]; *ppTmp != NULL; ppTmp = &(*ppTmp)->pNext)
		{
			printf("%d ", (*ppTmp)->Data);
		}
		printf("\n");
	}
}

2.4 在哈希表中寻找数据

int FindHashTable(int TmpData)
{
	int index = 0;
	LinkNode **ppTmp = NULL;

	index = TmpData % MAXLEN;			//先拿到键值,再去相应链表寻找
	for (ppTmp = &HashTable[index]; *ppTmp != NULL && TmpData >= (*ppTmp)->Data; ppTmp = &(*ppTmp)->pNext)					//在键值对应的链表遍历一遍寻找
	{
		if (TmpData == (*ppTmp)->Data)
		{
			return 1;
		}
	}

	return 0;
}

2.5 销毁哈希表

思想是销毁链表即可,因为哈希表就是多个链表组合起来的;

int DestroyHashTable(void)
{
	LinkNode *pTmpNode = NULL;
	LinkNode *pFreeNode = NULL;
	int i = 0;

	for (i = 0; i < MAXLEN; ++i)
	{
		pTmpNode = HashTable[i];
		pFreeNode = pTmpNode;
		while (pTmpNode != NULL)
		{
			pTmpNode = pTmpNode->pNext;
			free(pFreeNode);
			pFreeNode = pTmpNode;
		}
	}
	
	return 0;
}

三、 哈希表的调用

主函数中的内容是对上述几个函数的应用:

int main(int argc, const char *argv[])
{
	InsertHashTable(12);
	InsertHashTable(12);
	InsertHashTable(13);
	InsertHashTable(15);
	InsertHashTable(22);
	InsertHashTable(23);
	InsertHashTable(35);
	InsertHashTable(89);
	InsertHashTable(80);
	InsertHashTable(90);
	InsertHashTable(90);
	InsertHashTable(99);
	InsertHashTable(9);
	InsertHashTable(10);
	InsertHashTable(1);
	ShowHashTable();
	if (FindHashTable(80))
	{
		printf("Found!\n");
	}

	DestroyHashTable();
	
	return 0;
}

测试的结果如下:
在这里插入图片描述


总结

本期主要分享的是数据插入哈希表,在哈希表中查找数据,并且遍历哈希表的操作,哈希表是一种散列存储结构,在嵌入式应用中比较广泛,希望各位小伙伴们学起来,练起来,一起加油!最后,各位小伙伴们如果喜欢我的分享可以点赞收藏哦,你们的认可是我创作的动力,一起加油!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/757868.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux进程理解【环境变量】

Linux进程理解【环境变量】 提到环境变量&#xff0c;大家可能有些陌生&#xff0c;如果编写过Java就知道&#xff0c;编写Java需要提前安装JDK&#xff0c;这个操作就是配置Java的编码环境&#xff0c;在Linux中当然也少不了环境变量&#xff0c;下面我们就一起来看看 文章目…

SpringBoot 统一功能的处理

SpringBoot 统一功能的处理 文章目录 SpringBoot 统一功能的处理1. 用户登录权限校验1.1 最初用户登录验证1.2 Spring AOP 统一用户登录验证的问题1.3 SpringAOP 拦截器1.3.1 实现自定义拦截器1.3.2 将自定义拦截器加入到系统配置 1.4 拦截器实现原理1.4.1 实现流程图1.4.2 实现…

LeetCode:3. 无重复字符的最长子串

&#x1f34e;道阻且长&#xff0c;行则将至。&#x1f353; &#x1f33b;算法&#xff0c;不如说它是一种思考方式&#x1f340; 算法专栏&#xff1a; &#x1f449;&#x1f3fb;123 题解目录 一、&#x1f331;[3. 无重复字符的最长子串](https://leetcode.cn/problems/l…

分享维修一例DELL R540服务器黄灯无法开机故障

DELL PowerEdge R540服务器故障维修案例&#xff1a;&#xff08;看到文章就是缘分&#xff09; 客户名称&#xff1a;东莞市某街道管理中心 故障机型&#xff1a;DELL R540服务器 故障问题&#xff1a;DELL R540服务器无法开机&#xff0c;前面板亮黄灯&#xff0c;工程师通过…

私有GitLab仓库 - 本地搭建GitLab私有代码仓库并随时远程访问

文章目录 前言1. 下载Gitlab2. 安装Gitlab3. 启动Gitlab4. 安装cpolar内网穿透5. 创建隧道配置访问地址6. 固定GitLab访问地址6.1 保留二级子域名6.2 配置二级子域名 7. 测试访问二级子域名 前言 GitLab 是一个用于仓库管理系统的开源项目&#xff0c;使用Git作为代码管理工具…

javaee jstl表达式

jstl是el表达式的扩展 使用jstl需要添加jar包 package com.test.servlet;import java.io.IOException; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map;import javax.servlet.ServletException; import javax.servlet…

【C++】面向对象三大特性之继承

【C】面向对象三大特性之继承 继承的概念继承基类成员访问方式的变化子类到父类对象之间赋值兼容转换继承中的作用域子类的默认成员函数继承和友元、静态成员的关系菱形继承和菱形的虚拟继承虚拟继承解决二义性和数据冗余 继承的概念 继承&#xff1a;是面向对象程序设计使代码…

解析Android VNDK/VSDK Snapshot编译框架

1.背景 背景一&#xff1a; 为解决Android版本碎片化问题&#xff0c;引入Treble架构&#xff0c;它提供了稳定的新SoC供应商接口&#xff0c;引入HAL 接口定义语言&#xff08;HIDL/Stable AIDL&#xff0c;技术栈依然是Binder)&#xff0c;它指定了 vendor HAL 和system fr…

动态规划01背包之416分割等和子集(第10道)

题目&#xff1a; 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0c;使得两个子集的元素和相等。 示例&#xff1a; 解法&#xff1a; 先复习一下01背包问题&#xff1a; dp[i][j]的含义&#xff1a;从下标为[0-i]的物品里…

【Spring Boot】Spring Boot的系统配置 — 日志配置

日志配置 日志对于系统监控、故障定位非常重要&#xff0c;比如当生产系统发生问题时&#xff0c;完整清晰的日志记录有助于快速定位问题。接下来介绍Spring Boot对日志的支持。 1.Spring Boot日志简介 Spring Boot自带spring-boot-starter-logging库实现系统日志功能&#…

基于linux下的高并发服务器开发(第一章)- 目录操作函数

09 / 目录操作函数 &#xff08;1&#xff09;int mkdir(const char* pathname,mode_t mode); #include <sys/stat.h> #include <sys/types.h>int mkdir(const char *pathname, mode_t mode); 作用&#xff1a;创建一个目录 参数&#xff1a; pat…

固态硬盘SSD选型测试大纲

一&#xff0c;前言 目前不仅仅是家用电脑系统盘很多都采用了固态硬盘&#xff0c;很多工业产品也选用固态硬盘作为存储介质&#xff0c;这主要得益于固态硬盘相对于机械硬盘的优势。 固态硬盘(Solid State Disk)都是由主控芯片和闪存芯片组成&#xff0c;简单来说就是用固态电…

Python编程从入门到实践_5-10 检查用户名_答案

#《Python编程从入门到实践》&#xff0c;动手试一试&#xff0c;5-10检查用户名&#xff0c;答案。2023-07-15,by qs。 current_users [AaA,bBb,CcC,DdD,EeE] new_users [AAA,bbb,abc,def,hij] for new_user in new_users:current_users_1 []for current_user in current_u…

安达发|汽车零部件行业追溯系统的应用

汽车行业正处于一个蓬勃发展的阶段&#xff0c;随着客户需求的不断变化&#xff0c;生产厂商推出新款商品的速度也越来越快&#xff0c;新项目和变更的不断出现&#xff0c;就可能导致在交付的产品质量方面遇到各种各样的问题。如果这些质量问题得不到及时有效地追溯和控制&…

华为模拟器eNSP过程中所遇问题(40错误)与解决办法

1. 版本 2.打开ensp开启AR2204&#xff0c;报错40 3.弹出文档&#xff0c;挨着试一遍先 安装eNSP的PC上是否存在名为“VirtualBox Host-Only Network”的虚拟网卡 需要启用。虚拟网卡的设置是否符合以下要求&#xff1a;IP地址为192.168.56.1&#xff0c;子网掩码为255.255.2…

Typora设置Gitee图床,自动上传图片

之前写了一篇同类型文章&#xff1a;如何将Typora中图片上传到csdn 实现了Typora本地编辑的内容中的图片&#xff0c;可以直接复制到csdn上进行发布。但是在使用过程中发现sm.ms这个图床站不是很稳定&#xff0c;即使用了翻墙也不稳定。 这篇文章推荐使用Gitee作为图床&#xf…

C++教程(六)——数组

1 数组 1.1 概述 所谓数组&#xff0c;就是一个集合&#xff0c;里面存放了相同类型的数据元素 **特点1&#xff1a;**数组中的每个数据元素都是相同的数据类型 **特点2&#xff1a;**数组是由连续的内存位置组成的 12 一维数组 1.2.1 一维数组定义方式 一维数组定义的三…

FL Studio21编曲软件中文版如何下载更新?

国人习惯称之为水果&#xff0c;也是我个人现在在用的软件。FL Studio是一款比较全面的编曲软件&#xff0c;其通道机架可以使用户添加各种音频采样&#xff0c;快捷编辑节奏型。对于音频的剪辑、拼接、效果处理也非常优秀。非常适合电子音乐编曲以及一些Hiphop。但是其录音、以…

组合数学相关知识总结(目前主要总结了卡特兰数)

全排列 例子&#xff1a; n n n 个数取 m m m 个数有序排放 通项公式&#xff1a; A n m ( P n m ) n ∗ ( n − 1 ) ∗ ( n − 2 ) ∗ ⋅ ⋅ ⋅ ∗ ( n − m 1 ) n ! ( n − m ) ! A_n^m(P_n^m)n*(n-1)*(n-2)**(n-m1) \frac{n!}{(n-m)!} Anm​(Pnm​)n∗(n−1)∗(n−2)∗…

带你【玩转Linux命令】➾ diffstat file 每天2个day05

带你【玩转Linux命令】➾ diffstat & file 每天2个day05 &#x1f53b; 一、文件管理命令1.1 diffstat -根据diff的比较结果&#xff0c;显示统计数字1.2 file-辨识文件类型 &#x1f53b; 总结—温故知新 &#x1f448;【上一篇】 &#x1f496;The Begin&#x1f496; …