数据结构之哈希表(散列表)

哈希表:

可以将一个大范围内的元素通过哈希函映射数到一个较小范围内。

例如:如何将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;
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值