hlist哈希链表学习笔记

node1

node3

hlist数据结构有两个hlist_head和hlist_node

使用hash表是为了快速获取表中的数据,注重效率;哈希链表中,节点的插入操作都是插在链表头的位置

hlist结构

hlist_head只有一个域,即first -- 占用空间小

hlist_node有两个域,pprev是一个二级指针,指向前一个节点的next指针的地址 -- 由于hlist_head的first域指向的结点类型和hlist_node指向的下一个结点的结点类型相同,这样就解决了通用性

next = &node2 pprev = &head.first

next = NULL

first指针指向的是hlist_node1。first始终指向新插入的结点。

从而在表头插入的操作中可以通过一致的node->pprev访问和修改前结点的next(或first)指针

pprev = &node2.next

pprev是指向上一个节点的next的指针,next是指向hlist_node节点的指针,所以pprev是指向hlist_node指针的指针

添加节点

static inline void hlist_add_head(struct hlist_node *n, struct hlist_head *h)

{

struct hlist_node*first=h->first;//保存原首节点?

n->next=first;//新节点指向原首节点?

if(first)

first->pprev=&n->next;//如果first存在,更新它的pprev指向新节点的next

h->first = n;

n->pprev = &h->first;

}

h指向的是哈希表的特定的一个桶,first指向hlist的第一个数据节点

相关推荐
LuminousCPP3 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
魔法阵维护师3 小时前
从零开发游戏需要学习的c#模块,第十四章(保存和加载)
学习·游戏·c#
_李小白4 小时前
【android opencv学习笔记】Day 17: 目标追踪(MeanShift)
android·opencv·学习
一只机电自动化菜鸟5 小时前
一建机电备考笔记(40) 建筑机电施工—排水管道施工(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
2301_818730565 小时前
numpy的学习(笔记)
学习·numpy
GHL2842710905 小时前
Logon failed, use ctrl+c to cancel basic credential prompt
学习·prompt
共享家95275 小时前
Langchain的学习(二)
学习·langchain
victory04315 小时前
agent 学习路径解析 学习资源分享
学习
m0_629494736 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
咸甜适中7 小时前
rust语言学习笔记Trait(八)Iterator(迭代器)
笔记·学习·rust