数据结构----哈希表的插入与输出

复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
typedef int datatype;

typedef struct Node
{
    struct Node *next;
    datatype data;
}*Linklist;

//创建节点
Linklist Create_node()
{
    Linklist p=(Linklist)malloc(sizeof(struct Node));
    if(NULL==p)
        return NULL;
    //初始化指针域
    p->next=NULL;
    //初始化数据域
    p->data=0;
    return p;
}

//找到<=m的最大质数,m=待排列数的长度*4/3,返回下标
int prime_max(int m)                                                 
{
    for(int i=m;i>=2;m--)
    {
        int flag=0;
                //sqrt(i)《====》根号i
        for(int j=2;j<sqrt(i);j++)
        {
            if(i%j==0)
            {
                flag=1;
                break;
            }
        }
        if(flag==0)
            return i;
    }
}

//哈希表的插入

void hash_insert(int key,Linklist hash[],int m)
{
    int p=prime_max(m);
    int sub=key%p;
    Linklist head=hash[sub];//创建链表的头

    Linklist s=Create_node();//创建节点
    s->data=key;
    //判空
    if(NULL==head)
    {
        head=s;
        hash[sub]=s;
        return;
    }
    //存在多个节点
    s->next=head;
    head=s;
    hash[sub]=head;//更新哈希表的头
}
//哈希表的输出
void show(Linklist hash[],int m)
{
    for(int i=0;i<m;i++)
    {
        printf("%d: ",i);
        Linklist p=hash[i];//定义指针P指向哈希表的头
        while(p!=NULL)          //遍历哈希表,输出链表数据域的数据
        {
            printf("%d ",p->data);
            p=p->next;
        }
        printf("NULL\n");
    }
}

int main(int argc, const char *argv[])
{
    int arr[]={25,51,8,22,26,67,11,16,54,41};
    //将数据存入哈希表中
    int len=sizeof(arr)/sizeof(arr[0]);
    int m=len*4/3;
    Linklist hash[m];//定义指针数组
    for(int i=0;i<m;i++)
    {
        hash[i]=NULL;//防止野指针
    }
    for(int i=0;i<m;i++)//将数组中的元素插入到哈希表中
    {
        hash_insert(arr[i],hash,m);
    }
    //输出
    show(hash,m);
    return 0;
}

运行结果:

相关推荐
学编程就要猛4 小时前
数据结构初阶:Java中的Stack和Queue
数据结构
0南城逆流04 小时前
【STM32】知识点介绍三:哈希算法详解
stm32·嵌入式硬件·哈希算法
是苏浙4 小时前
零基础入门C语言之C语言实现数据结构之顺序表
c语言·开发语言·数据结构
星释4 小时前
Rust 练习册 :Matching Brackets与栈数据结构
数据结构·算法·rust
逐步前行7 小时前
C数据结构--排序算法
c语言·数据结构·排序算法
_dindong8 小时前
笔试强训:Week-4
数据结构·c++·笔记·学习·算法·哈希算法·散列表
陌路209 小时前
S12 简单排序算法--冒泡 选择 直接插入 希尔排序
数据结构·算法·排序算法
papership10 小时前
【入门级-算法-5、数值处理算法:高精度的乘法】
数据结构·算法
earthzhang202111 小时前
【1039】判断数正负
开发语言·数据结构·c++·算法·青少年编程
谈笑也风生11 小时前
只出现一次的数字 II(一)
数据结构·算法·leetcode