数据结构||hashmap,哈希表c语言链表实现

这篇博客详细介绍了链表结构的创建、添加、查找、删除等操作,并实现了一个简单的链表数据结构。此外,还讲解了哈希表的概念,包括哈希函数的计算、哈希表的创建、设置和获取值的方法,以及如何释放哈希表的内存。内容涵盖了数据结构和算法的基础知识。
摘要由CSDN通过智能技术生成
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

// 节点结构
typedef struct _int_list_node {
    //定义了一个节点的结构
    int value;
    struct _int_list_node * next; //这里不能简写,因为*int list node 还没有用typedef定义呢,所以只能写的麻烦一点
    struct _int_list_node * parent;
    char * key;
} * int_list_node;

// 链表结构
typedef struct _int_list {
   //链表的结构,链表有head tail length 
    int_list_node head;
    int_list_node tail;
    int length;
} * int_list;

int_list int_list_created(void);//就是函数声明吧
void int_list_push(int_list p, int value, char * key);
int int_list_eq(int_list p, int index);
void int_list_unshift(int_list p, int value, char * key);
void printList(int_list p);
void int_list_pop(int_list p);
void int_list_shift(int_list p);
void listfree(int_list p);
void insert (int index, int_list p_old, int_list p_new,int size);
void del (int_list p, int end, int strat);
int_list_node search (int_list p, char * key);

// 创建链表
int_list int_list_created(void){
   
    int_list p = (int_list)malloc(sizeof(struct _int_list));//就是给p指针申请内存
    p->head = NULL;//初始化一波
    p->tail = NULL;
    p->length = 0;
    return p;
}

// 向链表添加数据
void int_list_push(int_list p, int value, char * key){
   
    //key的首地址被存进来了
    if(p->length){
   //如果链表里面有数据
        p->tail->next = (int_list_node)malloc(sizeof(struct _int_list_node)); 
        p->tail->next->parent = p->tail;
        p->tail = p->tail->next;
    } else {
   //如果链表里面没有数据
        p->tail = (int_list_node)malloc(sizeof(struct _int_list_node)
C语言可以通过编写代码来实现通用数据结构,常见的通用数据结构包括线性表、栈、队列、数组和链表等。其中,线性表是最基本的数据结构,它可以使用数组或链表实现。数组是C语言内置的数据结构,具有固定长度和顺序存放的特点,可以通过下标直接访问元素。链表则是动态分配内存,可以灵活地插入和删除元素。 除了线性表,栈和队列也是常见的数据结构。栈是一种后进先出(LIFO)的数据结构,可以通过数组或链表实现。队列是一种先进先出(FIFO)的数据结构,同样可以使用数组或链表实现。 此外,C语言还可以使用其他数据结构,如哈希表(HashSet)和哈希映射(HashMap)。哈希表是一种通过哈希函数将数据映射到不同的桶中,用于快速查找和插入数据的数据结构。哈希映射则是在哈希表的基础上,将键值对存储在哈希表中。 总之,在C语言中,可以通过编写代码来实现各种通用数据结构,以满足不同的需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C语言实现常用数据结构:简要一览(第1篇)](https://blog.csdn.net/qq_43351159/article/details/107817198)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [c语言实现通用数据结构(一):通用链表](https://blog.csdn.net/swwlqw/article/details/22498833)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值