模拟哈希(开放地址法)

本题要求你模拟hash的保留余数法:取关键字被某个不大于哈希表表长m的数key除后所得余数为哈希地址。即 H(key) = key MOD m

现在有两种操作:

     1. 往hash表插入一个值为x正整数。 

     2.查询hash表的每个地址表示的值。

如果地址发生冲突,使用开放定址法: Hi = (H(key) + di) MOD m. 其中di = 1, 2, 3, …, m-1.

Input

 第一行输入两个个整数q1<=q<=100)和m(1<=m<=100)m表示hash表的表长,接下来输入q行。每行首先输入一个正整数c1<=c<=200),c1的时候表示操作1,然后再输入一个值为x的正整数,c2的时候表示操作2

 

Output

对于每一个操作2,输出当前hash表的每个地址的值(空的地址用0表示)。

Sample Input

3 10
1 5
1 15
2

Sample Output

0 0 0 0 0 5 15 0 0 0

#include<stdio.h>
int a[200];
int N,m;
int di=1;
int hashset(int key)
{
    return (key%m);
}

void hashput()
{
    for(int i=0;i<m-1;i++)
        printf("%d ",a[i]);
    printf("%d\n",a[m-1]);
}

int main(void)
{

    scanf("%d%d",&N,&m);
    while(N--)
    {
        int c,b;
        scanf("%d",&c);
        if(c==1)
        {
            scanf("%d",&b);
            int p = hashset(b);
            while(a[p]!=0 && di<=m-1)
            {
                p=(p+di)%m;
            }
            a[p]=b;
        }
        if(c==2)
        {
            hashput();
        }
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏代有工的玉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值