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的第一个数据节点

相关推荐
林鸿群2 小时前
Cocos2d-x 官方仓库学习总结
学习·游戏引擎·cocos2d
橘bird2 小时前
LangChain1.2 学习笔记(自用)(未完结)
笔记·python·学习·langchain
一叶落4382 小时前
LeetCode 135. 分发糖果(C语言)| 贪心算法 + 双向遍历详解
c语言·数据结构·算法·leetcode·贪心算法·哈希算法
吃着火锅x唱着歌2 小时前
PHP7内核剖析 学习笔记 第十章 扩展开发(3)
java·笔记·学习
for_ever_love__2 小时前
Objective-C 学习 NSString 和 NSMutableString的基本功能详解
学习·ios·objective-c
y = xⁿ2 小时前
【LeetCodehot100】T24:两两交换链表中的节点 T25:K个一组翻转链表
java·网络·数据结构·算法·链表
正经人_x3 小时前
学习日记33:Autoformer
学习
Yupureki3 小时前
《C++实战项目-高并发内存池》6.内存释放流程
c语言·开发语言·数据结构·c++·算法·哈希算法