8622 哈希查找

**思路:**

  1. 初始化哈希表,长度为 `length`。

  2. 使用哈希函数 `H(k) = 3 * k % length` 计算哈希地址。

  3. 采用线性探测法处理冲突。

  4. 插入关键字序列到哈希表中。

  5. 计算平均查找长度。

**伪代码:**

  1. 初始化哈希表 `H`,长度为 `length`。

  2. 定义哈希函数 `Hash`。

  3. 定义冲突处理函数 `collision`。

  4. 定义查找函数 `SearchHash`。

  5. 定义插入函数 `InsertHash`。

  6. 读取输入的哈希表长度 `length`。

  7. 读取关键字序列,插入哈希表。

  8. 输出哈希表内容。

  9. 计算并输出平均查找长度。

**C++代码:**

复制代码
#include "malloc.h" /* malloc()等 */
#include "stdlib.h" /* exit() */
#include "stdio.h"
#define EQ(a,b) ((a)==(b))
#define SUCCESS 1
#define UNSUCCESS 0
#define NULLKEY -1 /*哈希表无元素时值为-1*/
typedef int ElemType;
int length;
typedef struct {
    ElemType *elem; /* 数据元素存储基址,动态分配数组 */
    int count; /* 当前数据元素个数 */
} HashTable;

void InitHashTable(HashTable *H) {
    int i;
    (*H).count = 0; /* 当前元素个数为0 */
    (*H).elem = (ElemType*)malloc(length * sizeof(ElemType));
    if (!(*H).elem)
        exit(0); /* 存储分配失败 */
    for (i = 0; i < length; i++)
        (*H).elem[i] = NULLKEY; /* 未填记录的标志 */
}

unsigned Hash(ElemType K) {
    return (3 * K) % length;
}

void collision(int *p) {
    *p = (*p + 1) % length; /* 线性探测再散列 */
}

int SearchHash(HashTable H, ElemType K, int *p, int *c) {
    *p = Hash(K); /* 求得哈希地址 */
    while (H.elem[*p] != NULLKEY && !EQ(K, H.elem[*p])) {
        (*c)++;
        if (*c < length)
            collision(p); /* 求得下一探查地址p */
        else
            break;
    }
    if EQ(K, H.elem[*p])
        return SUCCESS; /* 查找成功,p返回待查数据元素位置 */
    else
        return UNSUCCESS; /* 查找不成功(H.elem[p].key==NULLKEY),p返回的是插入位置 */
}

int InsertHash(HashTable *H, ElemType e) {
    int c, p;
    c = 0;
    if (SearchHash(*H, e, &p, &c)) /* 表中已有与e有相同关键字的元素 */
        printf("哈希表中已有元素%d。\n", e);
    else { /* 插入e */
        (*H).elem[p] = e;
        ++(*H).count;
    }
    return c + 1; /*查找长度为冲突次数加1*/
}

void TraverseHash(HashTable H) {
    int i;
    for (i = 0; i < length; i++)
        if (H.elem[i] == NULLKEY) /* 有数据 */
            printf("X ");
        else
            printf("%d ", H.elem[i]);
    printf("\n");
}

int main() {
    float i = 0, j = 0;
    ElemType e;
    HashTable H;
    scanf("%d", &length);
    InitHashTable(&H);
    scanf("%d", &e);
    while (e != -1) {
        j++; /*j记录输入元素个数*/
        i = i + InsertHash(&H, e); /*i记录查找长度的和*/
        scanf("%d", &e);
    }
    TraverseHash(H);
    printf("Average search length=%f\n", i / j);
    return 0;
}

**总结:**

  • 使用哈希函数 `H(k) = 3 * k % length` 计算哈希地址。

  • 采用线性探测法处理冲突。

  • 插入关键字序列到哈希表中,并计算平均查找长度。

相关推荐
电鱼智能的电小鱼21 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun21 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书1 天前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
我是李武涯1 天前
从`std::mutex`到`std::lock_guard`与`std::unique_lock`的演进之路
开发语言·c++
yuuki2332331 天前
【数据结构】用顺序表实现通讯录
c语言·数据结构·后端
DashVector1 天前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会1 天前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗1 天前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚1 天前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实1 天前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针