码迷,mamicode.com
首页 > 其他好文 > 详细

hash查找

时间:2014-11-05 23:04:37      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:blog   io   ar   os   for   sp   div   log   bs   

#include<stdio.h>
#include<stdlib.h>
#include<iostream>
using namespace std; 

#define HASHSIZE 7
#define NULLKEY -32768 

struct HashTable{
	int *elem;
	int count;
};

void init(HashTable* hashTable)
{
	hashTable->elem = (int*)malloc(HASHSIZE * sizeof(int));
	hashTable->count = HASHSIZE; 
	for(int i = 0; i < HASHSIZE; i++)
		hashTable->elem[i] = NULLKEY; 
} 

int hash(int num)
{
	return num % HASHSIZE; 
} 

void insert(HashTable* hashTable, int data)
{
	int hash_address = hash(data); 

	while(hashTable->elem[hash_address] != NULLKEY)
	{
		hash_address = (++hash_address)% HASHSIZE; 
	}

	hashTable->elem[hash_address] = data; 
}

int search(HashTable* hashTable, int data)
{
	int hash_address = hash(data);

	while(hashTable->elem[hash_address] != data) 
	{
		hash_address = (++hash_address)% HASHSIZE; 
		if(hashTable->elem[hash_address] == NULLKEY || hash_address == hash(data)) return -1; 
	}
	return hash_address;
}

void display(HashTable* hashTable) 
{
	for(int i = 0; i < hashTable->count; i++)
		std::cout<<hashTable->elem[i]<<std::endl; 
}

int main()
{

	HashTable hashTable; 
	int a[HASHSIZE] = {13,29,27,28,26,30,38}; 

	init(&hashTable);
	for(int i = 0; i< HASHSIZE; i++)
	{
		insert(&hashTable, a[i]); 
	}
	display(&hashTable); 

	int result = search(&hashTable, 29); 
	std::cout<<result<<std::endl;

	return 0; 
}

 

hash查找

标签:blog   io   ar   os   for   sp   div   log   bs   

原文地址:http://www.cnblogs.com/kangbry/p/4077441.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!