poj2503

字典问题,根据输入的外文查找字典中对应的英文。用HASH做。

1.做完发现超时,仔细审查发现HASH函数写的很不好,虽然hash表长度很长,但是计算出的结果集中在一个区间内,分布十分不均匀。上网上找了一些专门处理字符串的hash函数,替换后效果好很多,顺利通过。

hash函数

//用跟元素个数最接近的质数作为散列表的大小
#define NHASH 29989
#define MULT 31

unsigned in hash(char *p)
{
    unsigned int h = 0;
    for (; *p; p++)
        h = MULT *h + *p;
    return h % NHASH;
}

#include<iostream>
using namespace std;

#define LEN 100003
struct node
{
	char English[11];
	char Forgien[11];
	node * next;
};

node dictionary[100000];
node *HashTable[LEN];
char w[11];

char input[100000][11];
unsigned int Hash(char *s);
void search(char *s);
int main()
{
	int i;
	int n=0;
	int m=0;
	unsigned int addr;
	char input[11];
	char t;
	node *p;
	
	while(gets(w)&&w[0]!='\0')  
    {  
        sscanf(w,"%s %s",dictionary[n].English,dictionary[n].Forgien);  
		addr=Hash(dictionary[n].Forgien);
        if(!HashTable[addr])
			HashTable[addr]=&dictionary[n];
		else
		{
			p=HashTable[addr];
			while(p->next)
				p=p->next;
			p->next=&dictionary[n];
		}
		n++;
	}
	while(cin>>input)
	{
		search(input);
	}
	return 0;
}

unsigned int Hash(char *s)
{
	unsigned int h=0;
	for(;*s;s++)
		h=31*h+*s;
	return h%LEN;
}
void search(char *s)
{
	unsigned int addr;
	node *p;
	addr=Hash(s);
	p=HashTable[addr];
	while(p)
	{
		if(0==strcmp(p->Forgien,s))
		{
			cout<<p->English<<endl;
			return;
		}
		else
			p=p->next;
	}
	cout<<"eh"<<endl;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值