设为首页 加入收藏

TOP

闭散列表的查找、插入和删除操作的完整C代码
2015-01-21 11:09:34 来源: 作者: 【 】 浏览:16
Tags:查找 插入 删除 操作 完整 代码
/*闭散列表的建立、查找、插入、删除*/
#include 
  
   

#define NIL -1  //假设关键字为非负整数
#define DEL -2

typedef int KeyType;
KeyType HashTable[13];  //便于验证算法,关键字个数假定为不超过13,哈希表长定为13

//关键字插入函数
void InsertHashTable(KeyType k)
{
	for(int i=0; i<13; i++)
		if( NIL == HashTable[(k%13+i)%13] || DEL == HashTable[(k%13+i)%13] ) {
			HashTable[(k%13+i)%13] = k;
			break;
		}

}

//哈希表的查找操作,查找成功则返回下表,否则返回-1
int HashSearch(KeyType k)
{
	int i = 0;
	while( i<13 ) {
		if( k == HashTable[((k%13)+i)%13] ) 
			return ((k%13)+i)%13;

		else if( NIL == HashTable[((k%13)+i)%13] ) 
			return -1;
		i++;
	}
	if( 13 == i ) 
		return -1;
}

//创建哈希表
void CreateHashTable()
{
	int n;
	KeyType key;
	for(int i=0; i<13; i++)
		HashTable[i] = NIL;
	printf("请输入关键字的个数:\n");
	scanf("%d", &n);
	printf("请输入%d个关键字的值:\n", n);
	for(i=0; i
   
    
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇OC学习篇之---循环引用问题 下一篇C语言BFS--Find a way(Hdu 2612)

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: