哈希表—拉链法

本文详细介绍了哈希表的拉链法实现,包括哈希表的初始化、节点插入、查找、删除和销毁等操作的代码实现,帮助读者深入理解拉链法在哈希表中的应用。
摘要由CSDN通过智能技术生成

哈希表的建立,初始化,节点的插入,查找,删除及哈希表的销毁的相关代码如下:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<assert.h>
typedef int KeyType; 
typedef int ValueType;
#define  primesize 8

typedef struct HashNode //哈希节点
{ 
KeyType _key; 
ValueType _value; 
struct HashNode* _next; 
}HashNode; 

typedef struct HashTable //哈希表
{ 
HashNode** _tables;//指针数组 
int _size; 
int _N; 
}HashTable; 
//建立一个哈希节点
HashNode* BuyHashNode(KeyType key, ValueType value)
{
  HashNode* node=(HashNode*)malloc(sizeof(HashNode));
  assert(node);
  node->_key=key;
  node->_value=key;
  node->_next=NULL;
  return node;

}
int HashFunc(KeyType key, int N)//确定数据在哈希表下的坐标
{
	return key%N;
}
int GetNextPrimeNum(int cur)//通过素数表来确定扩容大小
{
	 //int primesize=8;
	int i=0;
	  int primelist[primesize]={53,97,193,389,769,1543,3079,6151};
	  for( i=0;i<primesize;i++)
	  {
		  if(cur<pri
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值