哈希表的创建查询插入删除销毁

本文介绍了哈希表的基本操作,包括如何创建哈希表,使用链表解决冲突,以及查找、插入和删除元素的方法。通过示例代码展示了哈希表的动态操作过程,最后演示了如何销毁哈希表。
摘要由CSDN通过智能技术生成
#include<iostream>
using namespace std;

#define M 5

//定义数据类型
typedef  int ElemType ;

//定义哈希表上挂的链表的结点
typedef struct Node
{
	ElemType data;
	struct Node *next;

}Node,*pNode;

//定义哈希表上的表槽
typedef struct HashNode
{
	pNode first;//指向链表的第一个结点
}HashNode,*HashTable;

//创建一个具有n个表槽的哈希表
HashTable create_HashTable(int n)
{
	HashTable hashtable=(HashTable)malloc(n*sizeof(HashNode));
	if(!hashtable)
	{
		cout<<"哈希表分配空间失败"<<endl;
		exit(-1);
	}
	for(int i=0;i<n;i++)
	{
		hashtable[i].first=NULL;
	}
	return hashtable;
}


pNode search_HashTable(HashTable hashtable, ElemType data)
{
	pNode p;
	p=hashtable[data%M].first;
	if(!p)
		return NULL;
	else if(p->data==data)
		return p;
	
		while(p->next&&p->next->data!=data)
		{
			p=p->next;
		}
		return p->next;
	
	
	

}

bool insert_HashTable(HashTable hashtable,ElemType data)  
{
	pNode p,pNew;
	if(search_HashTable(hashtable,d
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值