哈希表:
可以将一个大范围内的元素通过哈希函映射数到一个较小范围内。
例如:如何将0~1e9内的数全都映射到0~1e5中呢,我们可以将所有大于1e5的数取一个模(哈希函数),将取模得到的数(小于1e5)放到0~1e5范围内存储。
哈希函数的一些说明:
1.当我们映射时,避免不了一些冲突(把多个元素映射的一个位置上了),处理冲突有拉链法和开放寻址法。
2.哈希函数我们一般采用取模的方式,并且当模的数是最接近边界的第一个质数时,哈希冲突的概率最小。例如,我们要映射到0~1e5中,那么我们取哈希函数为mod99991。
这里我们介绍拉链法:
当我们映射到的位置已经有一个数了的话(发生冲突),我们将该数直接连接到该位置的后面即可,可以用是链表实现,也可也是vector实现。
这里给出插入元素和查询元素的伪代码:
int h[N],e[N],ne[N],idx=0;//邻接表
//插入
void insert(int x){
int tmp=abs(x)%mod;//哈希函数
e[idx]=x,ne[idx]=h[tmp],h[tmp]=idx++;//插入操作
return;
}
//查询
bool query(int x){
int tmp=abs(x)%mod;
for(int i=h[tmp];i!=-1;i=ne[i])
if(e[i]==x)return true;
return false;
}