图书管理(hash表)

#10034. 「一本通 2.1 例 2」图书管理
传统1000 ms512 MiB
1505
通过
4292
提交
题目描述
图书管理是一件十分繁杂的工作,在一个图书馆中每天都会有许多新书加入。为了更方便的管理图书(以便于帮助想要借书的客人快速查找他们是否有他们所需要的书),我们需要设计一个图书查找系统。

该系统需要支持 2 种操作:

add(s) 表示新加入一本书名为 s 的图书。
find(s) 表示查询是否存在一本书名为 s 的图书。
输入格式
第一行包括一个正整数 n,表示操作数。 以下 n 行,每行给出 2 种操作中的某一个指令条,指令格式为:

add s
find s
在书名 s 与指令(add,find)之间有一个隔开,我们保证所有书名的长度都不超过 200。可以假设读入数据是准确无误的。

输出格式
对于每个 find(s) 指令,我们必须对应的输出一行 yes 或 no,表示当前所查询的书是否存在于图书馆内。

注意:一开始时图书馆内是没有一本图书的。并且,对于相同字母不同大小写的书名,我们认为它们是不同的。

样例
输入
4
add Inside C#
find Effective Java
add Effective Java
find Effective Java
输出
no
yes
数据范围与提示
n \le {30000}。

整体思路

在将一个串输入进去后,就求它所对应的hash值,然后查找,如果没有的话就看要求是查找还是插入查找就false,插入就将这个值插入对应的hash值所对应的链表,注意字符串的输入格式

完整代码

#include
using namespace std;
int ii=0,n;//ii表示输入的是第几行
string t[30010],cmd;//设定多个字符串,
///注意每一行就是一个字符串,cmd输入的是add还是find
int hed[10000001],nxt[30010];//链表函数hed表示头,nxt表示尾
const int b=7;//进制数
int h(string s)
{
	int m=0;
	for(int i=0;i<s.size();i++) m=(m*b+s[i]-'A'+1)%10000001;
	return m;
}//运用字符串hash的转换方法转换为进制数然后取模
//(为了不抄内存)
bool insert(int s,int way)//way表示的是0或1,
//0表示的是add,1表示的是find
{
	int v=h(t[s]);//找到这一串的hash值
	int u=hed[v];//这个hash值所对应的头(第一个值)
	while(u)//只要还有一个u
	{
		if(t[u]==t[s])return true;//如果找到了的话return true
		u=nxt[u];//接着找下一个同一hash值所对应的数
	}
	if(way==1)return false;//1证明在查找还没找到,false
	nxt[s]=hed[v];hed[v]=s;//将这个串所对应的序号数插入第一个
	return true;
}
int main()
{
	cin>>n;getchar();//注意这里的getchar不能丢!!!
	for(int i=1;i<=n;i++)
	{
		cin>>cmd;
		getchar();ii++;
		getline(cin,t[ii]);
		if(cmd[0]=='a')
			insert(ii,0);
		else
		{
			if(insert(ii,1))cout<<"yes"<<endl;
			else cout<<"no"<<endl;
		}
	}
	return 0;
}

你可能感兴趣的:(哈希算法,算法)