哈希表--开散列表

本文介绍了开散列表的代码实现,包括`HashBucket.h`、`HashBucket.c`和`test.c`文件,以及引用了通用头文件`comm.h`和`HashBucket.h`。
摘要由CSDN通过智能技术生成

下面为开散列表的代码实现:

闭散列表代码实现参考:https://blog.csdn.net/virgofarm/article/details/80396215

HashBucket.h

#ifndef __HASHBUCKET_H__
#define __HASHBUCKET_H__


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



typedef int DataType;

typedef size_t(*PDTInt)(DataType str);


//哈希桶的每个节点类型
typedef struct HashBucketNode
{
    DataType _data;
    struct HashBucketNode* _pNext;
}HBN;


//哈希桶类型
typedef struct HushBucket
{
    HBN** _table;    //哈希桶空间--放的是节点的地址,所以是二级指针
    int _capacity;    //空间容量
    int _size;       //共有多少个有效元素--总节点个数
    PDTInt pDTInt;   //将数据类型转化为整形,因为哈希函数除留余数法
}HBucket;



//初始化
void HashBucketInit(HBucket* ht, int capacity, PDTInt pDTInt);

//创建哈希桶节点
HBN* BuyHushBucketNode(DataType data);

//插入元素 -- data唯一
void HashBucketInsertUnique(HBucket* ht, DataType data);

//删除元素--data唯一
void HashBucketDeleteUnique(HBucket* ht, DataType data);

//插入元素--data不唯一
void HashBucketInsertEqual(HBucket* ht, DataType data);

//删除所有值为data的节点
void HashBucketDeleteEqual(HBucket* ht, DataType data);

//哈希桶中共有多少个节点
int HashBucketSize(HBucket* ht);

//判空
int HashBucketEmpty(HBucket* ht);

//哈希桶中共有多少个桶
int HashBucketCount(HBucket* ht);

//在桶号为BucketNO的桶中有多少个节点
int HashBucketBucketSize(HBucket* ht, int BucketNo);

//打印哈希桶
void PrintHashBucket(HBucket* ht);

//销毁哈希桶
void HashBucketDestroy(HBucket* ht);


#endif

HashBucket.c

#include "HashBucket.h"
#include "comm.h"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值