哈希表闭散列(代码实现)

HashClose.h

#pragma once 



#include <stddef.h>



size_t HashMaxSize=1000;

typedef enum Stat { 

Empty, 

Valid, 

Invalid // 当前元素被删除了 

} Stat; 



typedef int KeyType; 

typedef int ValType; 



typedef size_t (*HashFunc)(KeyType key); 



typedef struct HashElem { 

KeyType key; 

ValType value; 

Stat stat; // 引入一个 stat 标记来作为是否有效的标记 

} HashElem; 



typedef struct HashTable { 

HashElem *data; 

size_t size; 

HashFunc hash_func; 

} HashTable; 



void HashInit(HashTable* ht, HashFunc fp); 



int HashInsert(HashTable* ht, KeyType key, ValType value); 



// 输入key, 查找对应key的value. 

int HashFind(HashTable* ht, KeyType key, ValType* value); 



void HashRemove(HashTable* ht, KeyType key); 



int HashEmpty(HashTable* ht); 



size_t HashSize(HashTable* ht); 



void HashDestroy(HashTable* ht); 

HashClose.c

  ShowTable(&ht,(char*)"insert 600 element");

  printf("HashMaxSize:%lu\n", HashMaxSize);

}



void TestRemove()

{

    TEST_HEADER;

    HashTable ht;

    HashInit(&ht,HashFun);



    int i;

    for(i=0;i<600;i++)

    {

      HashInsert(&ht,i,i*4);

    }

  

    ShowTable(&ht,(char*)"first insert 600 element");



    for(i=0;i<600;i++)

    {

      HashRemove(&ht,i);

    }

    ShowTable(&ht,(char*)"remove  600 element");





    for(i=0;i<600;i++)

    {

      HashInsert(&ht,i,i*4);

    }



    ShowTable(&ht,(char*)"second insert  600 element");

}

void TestDestory()

{

  

    TEST_HEADER;

    HashTable ht;

    HashInit(&ht,HashFun);

    HashInsert(&ht,3,24);

    HashDestroy(&ht);

    ShowTable(&ht,(char*)"Destroy");

}

int main()

{

  TestInit();

  TestInsert();

  TestRemove();

  TestDestory();

  return 0;

}


Makefile

HashClose: HashClose.c
	gcc -o $@  $^
.PHONY:clean
clean:
	rm HashClose


运行结果:

[abc123@localhost hash_close]$ ./HashClose 

=================TestInit=================

-------HashInit-------

      HashTable      
data :   0xade010
size :          0
func :   0x400610

=================TestInsert=================

-------before insert -------

      HashTable      
data :   0xae0f00
size :          0
func :   0x400610
HashMaxSize:1000

-------insert 600 element-------

      HashTable      
data :   0xae3df0
size :        600
func :   0x400610
HashMaxSize:2001

=================TestRemove=================

-------first insert 600 element-------

      HashTable      
data :   0xae9bd0
size :        600
func :   0x400610

-------remove  600 element-------

      HashTable      
data :   0xae9bd0
size :          0
func :   0x400610

-------second insert  600 element-------

      HashTable      
data :   0xae9bd0
size :        600
func :   0x400610

=================TestDestory=================

-------Destroy-------

      HashTable      
data :      (nil)
size :          0
func :      (nil)
[abc123@localhost hash_close]$ 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值