数据结构哈希表怎么画(数据结构哈希算法)

数据结构哈希表参考代码如下:/* 名称:哈希表 语言:数据结构C语言版 编译环境:VC++6.0 日期:2014-3-26*/#include#include#include#defineNULLKEY0 //0为无记录标志#defineN10 //数据元素个数typedefintKeyType;//设关键字域为整型

大家好,又见面了,我是你们的朋友全栈君。

数据结构哈希表

参考代码如下:

/*
	名称:哈希表 
	语言:数据结构C语言版 
	编译环境:VC++ 6.0
	日期: 2014-3-26 
*/


#include <stdio.h>
#include <malloc.h>
#include <windows.h>


#define NULLKEY 0	// 0为无记录标志 
#define N 10		// 数据元素个数 

typedef int KeyType;// 设关键字域为整型 

typedef struct
{
	KeyType key;
	int ord;
}ElemType; // 数据元素类型 

// 开放定址哈希表的存储结构 
int hashsize[]={11,19,29,37}; // 哈希表容量递增表,一个合适的素数序列 
int m=0; // 哈希表表长,全局变量 

typedef struct
{
	ElemType *elem; // 数据元素存储基址,动态分配数组 
	int count; // 当前数据元素个数 
	int sizeindex; // hashsize[sizeindex]为当前容量 
}HashTable;

#define SUCCESS 1
#define UNSUCCESS 0
#define DUPLICATE -1


// 构造一个空的哈希表
int InitHashTable(HashTable *H)
{  
	int i;
	(*H).count=0; // 当前元素个数为0 
	(*H).sizeindex=0; // 初始存储容量为hashsize[0] 
	m=hashsize[0];
	(*H).elem=(ElemType*)malloc(m*sizeof(ElemType));
	if(!(*H).elem)
		exit(0); // 存储分配失败 
	for(i=0;i<m;i++)
		(*H).elem[i].key=NULLKEY; // 未填记录的标志 
	
	return 1;
}

//  销毁哈希表H
void DestroyHashTable(HashTable *H)
{ 
	free((*H).elem);
	(*H).elem=NULL;
	(*H).count=0;
	(*H).sizeindex=0;
}

// 一个简单的哈希函数(m为表长,全局变量)
unsigned Hash(KeyType K)
{ 
	return K%m;
}

// 开放定址法处理冲突
void collision(int *p,int d) // 线性探测再散列 
{  
	*p=(*p+d)%m;
}

// 在开放定址哈希表H中查找关键码为K的元素,若查找成功,以p指示待查数据 
// 元素在表中位置,并返回SUCCESS;否则,以p指示插入位置,并返回UNSUCCESS 
// c用以计冲突次数,其初值置零,供建表插入时参考。
int SearchHash(HashTable H,KeyType K,int *p,int *c)
{
	*p=Hash(K); // 求得哈希地址 
	while(H.elem[*p].key!=NULLKEY&&!(K == H.elem[*p].key))
	{
		// 该位置中填有记录.并且关键字不相等 
		(*c)++;
		if(*c<m)
			collision(p,*c); // 求得下一探查地址p 
		else
			break;
	}
	if (K == H.elem[*p].key)
		return SUCCESS; // 查找成功,p返回待查数据元素位置 
	else
		return UNSUCCESS; // 查找不成功(H.elem[p].key==NULLKEY),p返回的是插入位置 
}

int InsertHash(HashTable *,ElemType); // 对函数的声明 

// 重建哈希表
void RecreateHashTable(HashTable *H) // 重建哈希表 
{ 
	int i,count=(*H).count;
	ElemType *p,*elem=(ElemType*)malloc(count*sizeof(ElemType));
	p=elem;
	printf("重建哈希表\n");
	for(i=0;i<m;i++) // 保存原有的数据到elem中 
		if(((*H).elem+i)->key!=NULLKEY) // 该单元有数据 
			*p++=*((*H).elem+i);
	(*H).count=0;
	(*H).sizeindex++; // 增大存储容量 
	m=hashsize[(*H).sizeindex];
	p=(ElemType*)realloc((*H).elem,m*sizeof(ElemType));
	if(!p)
		exit(0); // 存储分配失败 
	(*H).elem=p;
	for(i=0;i<m;i++)
		(*H).elem[i].key=NULLKEY; // 未填记录的标志(初始化) 
	for(p=elem;p<elem+count;p++) // 将原有的数据按照新的表长插入到重建的哈希表中 
		InsertHash(H,*p);
}

// 查找不成功时插入数据元素e到开放定址哈希表H中,并返回1; 
// 若冲突次数过大,则重建哈希表。
int InsertHash(HashTable *H,ElemType e)
{
	int c,p;
	c=0;
	if(SearchHash(*H,e.key,&p,&c)) // 表中已有与e有相同关键字的元素 
		return DUPLICATE;
	else if(c<hashsize[(*H).sizeindex]/2) // 冲突次数c未达到上限,(c的阀值可调) 
	{
		// 插入e 
		(*H).elem[p]=e;
		++(*H).count;
		return 1;
	}
	else
		RecreateHashTable(H); // 重建哈希表 
	
	return 0;
}

// 按哈希地址的顺序遍历哈希表
void TraverseHash(HashTable H,void(*Vi)(int,ElemType))
{  
	int i;
	printf("哈希地址0~%d\n",m-1);
	for(i=0;i<m;i++)
		if(H.elem[i].key!=NULLKEY) // 有数据 
			Vi(i,H.elem[i]);
}

// 在开放定址哈希表H中查找关键码为K的元素,若查找成功,以p指示待查数据 
// 元素在表中位置,并返回SUCCESS;否则,返回UNSUCCESS 
int Find(HashTable H,KeyType K,int *p)
{
	int c=0;
	*p=Hash(K); // 求得哈希地址 
	while(H.elem[*p].key!=NULLKEY&&!(K == H.elem[*p].key))
	{ // 该位置中填有记录.并且关键字不相等 
		c++;
		if(c<m)
			collision(p,c); // 求得下一探查地址p 
		else
			return UNSUCCESS; // 查找不成功(H.elem[p].key==NULLKEY) 
	}
	if (K == H.elem[*p].key)
		return SUCCESS; // 查找成功,p返回待查数据元素位置 
	else
		return UNSUCCESS; // 查找不成功(H.elem[p].key==NULLKEY) 
}


void print(int p,ElemType r)
{
	printf("address=%d (%d,%d)\n",p,r.key,r.ord);
}

int main()
{
	ElemType r[N] = {
		{17,1},{60,2},{29,3},{38,4},{1,5},
		{2,6},{3,7},{4,8},{60,9},{13,10}
	};
	HashTable h;
	int i, j, p;
	KeyType k;
	
	InitHashTable(&h);
	for(i=0;i<N-1;i++)
	{
		// 插入前N-1个记录 
		j=InsertHash(&h,r[i]);
		if(j==DUPLICATE)
			printf("表中已有关键字为%d的记录,无法再插入记录(%d,%d)\n",
				r[i].key,r[i].key,r[i].ord);
	}
	printf("按哈希地址的顺序遍历哈希表:\n");
	TraverseHash(h,print);
	printf("请输入待查找记录的关键字: ");
	scanf("%d",&k);
	j=Find(h,k,&p);
	if(j==SUCCESS)
		print(p,h.elem[p]);
	else
		printf("没找到\n");
	j=InsertHash(&h,r[i]); // 插入第N个记录 
	if(j==0) // 重建哈希表 
		j=InsertHash(&h,r[i]); // 重建哈希表后重新插入第N个记录 
	printf("按哈希地址的顺序遍历重建后的哈希表:\n");
	TraverseHash(h,print);
	printf("请输入待查找记录的关键字: ");
	scanf("%d",&k);
	j=Find(h,k,&p);
	if(j==SUCCESS)
		print(p,h.elem[p]);
	else
		printf("没找到\n");
	DestroyHashTable(&h);
	
	system("pause");
	return 0; 
}

/*
输出效果:

表中已有关键字为60的记录,无法再插入记录(60,9)
按哈希地址的顺序遍历哈希表:
哈希地址0~10
address=1 (1,5)
address=2 (2,6)
address=3 (3,7)
address=4 (4,8)
address=5 (60,2)
address=6 (17,1)
address=7 (29,3)
address=8 (38,4)
请输入待查找记录的关键字: 17
address=6 (17,1)
重建哈希表
按哈希地址的顺序遍历重建后的哈希表:
哈希地址0~18
address=0 (38,4)
address=1 (1,5)
address=2 (2,6)
address=3 (3,7)
address=4 (4,8)
address=6 (60,2)
address=10 (29,3)
address=13 (13,10)
address=17 (17,1)
请输入待查找记录的关键字: 13
address=13 (13,10)
请按任意键继续. . .

*/ 

运行结果如下:

数据结构哈希表怎么画(数据结构哈希算法)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128275.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月11日 下午7:20
下一篇 2022年4月11日 下午7:20


相关推荐

  • WAP网站设计之xhtml mp

    WAP网站设计之xhtml mpWAP 网站设计之 xhtmlmp 作者 99770 动漫网 来源 hi baidu com 大中小 浏览 1971 添加日期 2010 05 11 我要评论 1 nbsp nbsp nbsp 一 XHTMLMP 的语法规则我们知道 我们通常用电脑访问的网站的网页是用 html 构建的 类似的 现在 WAP2 0 网站是用 XHTMLMP 构建 以供手持设备的访问 如手机 PDA 等 XHTMLMP 是 XHT

    2026年3月18日
    2
  • docker离线安装配置

    docker离线安装配置1、下载docker的安装文件下载地址这里下载docker-20.10.8.tgz,将docker-20.10.8.tgz文件上传到系统上:将解压出来的docker文件内容移动到/usr/bin/目录下进入/etc/systemd/system/目录,并创建docker.service文件编辑docker.service:打开docker.service文件,将以下内容复制:[Unit]Description=DockerApplicationContainerEngin

    2026年4月13日
    4
  • 执行SQL语句的优先级顺序

    执行SQL语句的优先级顺序FROM 执行顺序为从后往前 从右到左 数据量较大的表尽量放在后面 WHERE 执行顺序为自下而上 从右到左 将能过滤掉最大数量记录的条件写在 WHERE 字句的最右 GROUPBY 执行顺序从右往左分组 最好在 GROUPBY 前使用 WHERE 将不需要的记录在 GROUPBY 之前过滤掉 HAVING 消耗资源 尽量避免使用 HAVING 会在检索出所有记录之后才对结果进行过滤 需要排序等操作 ORDERBY 执行顺序从左到右 消耗资源 SELECT 少用星号 尽量使用字段名称 oracle 在解析的过

    2026年3月17日
    2
  • vba 数组填充单元格

    vba 数组填充单元格Sub 数组填充单元格 Dimaaa 3 3 Dimtemp 0 2 aaa 0 0 姓名 aaa 0 1 llll aaa 0 2 jjjj aaa 1 0 性别 aaa 1 1 男 aaa 1 2 女 aaa 2 0 序号 aaa 2 1 1 aaa 2 2 2 Ra

    2026年3月17日
    1
  • python爬虫的4个实例

    python爬虫的4个实例文章目录1、京东商品页面的爬取2、亚马逊商品页面的爬取3、百度、360搜索关键字提交1、京东商品页面的爬取爬虫具体流程可以参照前一篇博客:https://blog.csdn.net/weixin_42515907/article/details/87932185importrequestsurl=&quot;https://item.jd.com/3112072.html&quot;try:…

    2022年5月7日
    43
  • 51单片机最小系统解读

    51单片机最小系统解读提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、51单片机最小系统模块构成二、电源电路1.电源引脚三、时钟电路1.外部晶振引脚2.晶振(时钟电路)3.时钟电路小tips四、复位电路1.按键复位2.上电复位总结前言在学习51单片机的时候我们最先接触到的就是单片机最小系统,单片机最小系统又叫最小应用系统,顾名思义就是能够使单片机实现简单运行的最少原件的组合。提示:以下将以51单片机最小系统为例进行介绍一、51单片机最小系统模块构成二、电源电路一个系统的

    2022年6月23日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号