当前位置:  编程技术>c/c++/嵌入式

哈希表实验C语言版实现

    来源: 互联网  发布时间:2014-10-17

    本文导语:  代码如下:/* 数据结构C语言版 哈希表 */#include #include #define NULLKEY 0 // 0为无记录标志 #define N 10  // 数据元素个数 typedef int KeyType;// 设关键字域为整型 typedef struct{ KeyType key; int ord;}ElemType; // 数据元素类型 // 开放定址哈希表的...

代码如下:

/*
 数据结构C语言版 哈希表

*/
#include
#include
#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

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。




特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3