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

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

运行结果:

相关推荐
胡萝卜3.01 小时前
数据结构初阶:排序算法(一)插入排序、选择排序
数据结构·笔记·学习·算法·排序算法·学习方法
lyx33136967591 小时前
Pandas数据结构详解Series与DataFrame
数据结构·pandas
散1122 小时前
01数据结构-交换排序
数据结构·算法
浮灯Foden6 小时前
算法-每日一题(DAY13)两数之和
开发语言·数据结构·c++·算法·leetcode·面试·散列表
山顶风景独好10 小时前
【Leetcode】随笔
数据结构·算法·leetcode
科大饭桶11 小时前
C++入门自学Day11-- String, Vector, List 复习
c语言·开发语言·数据结构·c++·容器
Cx330❀13 小时前
【数据结构初阶】--排序(四):归并排序
c语言·开发语言·数据结构·算法·排序算法
艾莉丝努力练剑14 小时前
【C语言16天强化训练】从基础入门到进阶:Day 1
c语言·开发语言·数据结构·学习
番薯大佬14 小时前
编程算法实例-冒泡排序
数据结构·算法·排序算法
ankleless15 小时前
数据结构(03)——线性表(顺序存储和链式存储)
数据结构·考研·链表·顺序表·线性表