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

复制代码
#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;
}

运行结果:

相关推荐
多吃蔬菜!!!2 小时前
排序算法C语言实现
数据结构
零叹2 小时前
篇章六 数据结构——链表(二)
数据结构·链表·linkedlist
-qOVOp-6 小时前
408第一季 - 408内容概述
数据结构
闪电麦坤958 小时前
数据结构:泰勒展开式:霍纳法则(Horner‘s Rule)
数据结构·算法
枣伊吕波8 小时前
第十三节:第四部分:集合框架:HashMap、LinkedHashMap、TreeMap
java·哈希算法
小河豚oO11 小时前
LeetCode 热题 100 - 哈希 - 128
算法·leetcode·哈希算法
客卿12311 小时前
力扣100题之128. 最长连续序列
算法·leetcode·哈希算法
码农开荒路12 小时前
Redis底层数据结构之字典(Dict)
java·数据结构·数据库·redis
lyh134413 小时前
【Fiddler抓取手机数据包】
数据结构
int型码农14 小时前
数据结构第八章(二)-交换排序
c语言·数据结构·算法·排序算法