【模拟散列表】

题目

拉链法

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5+3;
#define null -1
int h[N], ne[N], e[N], idx;
void insert(int x)
{
    int k = (x % N + N) % N;
    e[idx] = x;
    ne[idx] = h[k];
    h[k] = idx++;
}
bool find(int x)
{
    int k = (x % N + N) % N;
    for(int i = h[k]; i != null; i = ne[i])
    {
        if(e[i] == x) return true;
    }
    
    return false;
}
int main()
{
    memset(h, null, sizeof h);

    int n;
    scanf("%d", &n);
    char op[2];
    int num;
    for(int i = 1; i <= n; i++)
    {
        
        scanf("%s %d", op, &num);
        int t = find(num);
        if(op[0] == 'I')
        {
            insert(num);
        }
        else
        {
            if(find(num)) puts("Yes");
            else puts("No");
        }
       
    }
    
    return 0;
}

注意

由于值域大于散射域,存在散射结果相同的情况,但是散射对象的数目是固定的,就是散射域的大小。

h数组用散射结果来访问,ne和e用当前指针来访问或者用h数组的内容来访问

insert函数:首先得到散射结果、然后利用当前指针存储e、结合h[k]和当前指针来头插,修改h[k]值为当前指针,当前指针增加。

find函数:首先得到散射结果、初始化头指针、以-1作为停止条件i = ne[i]作为迭代条件,找到e[i] == x就返回true,不然返回false;

开放寻址法

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+3;
#define null 0x3f3f3f3f
int h[N];
int find(int x)
{
    int i = (x % N + N) % N;
    while(h[i] != null && h[i] != x)
    {
        i++; 
        if(i == N) i = 0;
    }

    return i;
}
int main()
{
    memset(h, 0x3f, sizeof h);

    int n;
    scanf("%d", &n);
    char op[2];
    int num;
    for(int i = 1; i <= n; i++)
    {

        scanf("%s %d", op, &num);
        int t = find(num);
        if(op[0] == 'I')
        {
            h[t] = num;
        }
        else
        {
            if(h[t] != null) puts("Yes");
            else puts("No");
        }

    }

    return 0;
}

注意

find函数返回的是空地址或者是x的存在地址。循环条件是(不空) && (不是)

理解:空了就返回空地址,不空而且是就返回存在地址。

前面储存数值在e,后面在h本身,所以后面不能拿-1来当空指针

相关推荐
Old Uncle Tom10 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆10 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移10 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业11 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业13 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
JasmineX-114 小时前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
.54814 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove14 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊14 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf16 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源