模拟散列表

拉链法

#include<iostream>
#include<cstring>
using namespace std;
const int N = 100003;//N的值为质数,而且离2的幂越远越好,这样不容易冲突
int h[N], e[N], ne[N], idx;
void insert(int x)
{
    int k = (x % N + N) % N;
    e[idx] = x;
    ne[idx] = h[k];
    h[k] = idx ++;
}

int find(int x)
{
    int k = (x % N + N ) % N;
    for(int i = h[k]; i != -1; i = ne[i])
    {
        if(e[i] == x)return true;
    }
    return false;
}
int main()
{
    memset(h, -1, sizeof h);
    int n;
    cin >> n;
    while(n --)
    {
        char op[2];
        int x;
        cin >> op >> x;
        if(*op == 'I')insert(x);
        else {
            if(find(x))puts("Yes");
            else puts("No");
        }
    }
}

开放寻址法

#include<iostream>
#include<cstring>
using namespace std;
const int N = 200003, nu = 0x3f3f3f3f;//N一般是题目给的2~5倍。
int h[N];
int find(int x)
{
    int k = (x % N + N) % N;
    while(h[k] != nu && h[k] != x)
    {
        k ++;
        if(k == N)k = 0;
    }
    return k;
}
int main()
{
    int n;
    memset(h, 0x3f, sizeof h);
    cin >> n;
   
    while(n --)
    {
        char op[2];
        int x;
        cin >> op >> x;
        int k = find(x);
        if(*op == 'I')
        {
            h[k] = x;
        }
        else if(*op == 'Q'){
            if(h[k] == nu)puts("No");
            
            else puts("Yes");
        }
    }
}
数据结构 文章被收录于专栏

数据结构

全部评论

相关推荐

11-13 20:32
门头沟学院 Java
面向未来编程code:我没看到他咋急,他不就问你个问题。。。
点赞 评论 收藏
分享
最近又搬回宿舍了,在工位坐不住,写一写秋招起伏不断的心态变化,也算对自己心态的一些思考表演式学习从开始为实习准备的时候就特别焦虑,楼主一开始选择的是cpp后端,但是24届这个方向已经炸了,同时自己又因为本科非92且非科班,所以感到机会更加迷茫。在某天晚上用java写出hello&nbsp;world并失眠一整晚后选择老本行干嵌入式。理想是美好的,现实情况是每天忙但又没有实质性进展,总是在配环境,调工具,顺带还要推科研。而这时候才发现自己一直在表演式学习,徘徊在设想如何展开工作的循环里,导致没有实质性进展。现在看来当时如果把精力专注在动手写而不是两只手端着看教程,基本功或许不会那么差。实习的焦虑5月,楼主...
耶比:哲学上有一个问题,玛丽的房间:玛丽知道眼睛识别色彩的原理知道各种颜色,但是她生活在黑白的房间里,直到有一天玛丽的房门打开了她亲眼看到了颜色,才知道什么是色彩。我现在最大可能的减少对非工作事情的思考,如果有一件事困扰了我, 能解决的我就直接做(去哪里或者和谁吵架等等……),解决不了的我就不想了,每一天都是最年轻的一天,珍惜今天吧
投递比亚迪等公司10个岗位 > 秋招被确诊为…… 牛客创作赏金赛
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务