自学嵌入式第二十六天:数据结构-哈希表、内核链表

一、哈希表

1.提供一种可以存储和查找的数据结构,为了提高查找的速度而生;时间复杂度是(O(1)-O(logn));

2.对需要统计的数字直接定址;

fun(key)=存储位置;key是要存储的数据;

fun叫哈希函数,把key值转成存储的下标;

key可以是数可以是其他数据;

用于存储数据的空间一般是一段连续的存储空间;

3.哈希函数(fun)设计的要求:计算尽量快捷方便,地址尽量均匀;

对于数字一般是求余;

冲突:fun(key1)==fun(key2)

线性探测,+1,+2...

二次探测,+1,-1,+2,-2....

随机探测,rand()

二、快速排序

取中间值,把小于中间值的数调到左边,大于中间值的数调到右边;

连续递归;

三、内核链表

1.在内核中链表结点仅有两个指针,且是双向循环链表;

2.数据域和指针域分离;链表的功能扩展能力变强

3.container_of(tmp,per,node)

使用container_of带参宏可以得到指向数据的指针;

4.list_for_each_entry_safe(pos,n,head,member)

遍历

pos:当前要访问的数据的结构体指针,n是pos的下一个,head是链表的头结点,member是自定义的结构体中结点的变量名;

5.head头结点不包含有效元素,head->next是链表中第一个有效数据;

相关推荐
apcipot_rain1 小时前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
JAVA面经实录9178 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
影视飓风TIM10 小时前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
牛油果子哥q11 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
一切皆是因缘际会12 小时前
LLM轻量化联邦微调机理
数据结构·人工智能·数学建模·ai
玖玥拾13 小时前
C/C++ 数据结构(六)链表迭代器与底层
c语言·数据结构·c++·链表·stl库
牛油果子哥q13 小时前
AVL平衡树与红黑树深度精讲对比,平衡因子、四大旋转原理、着色规则、平衡策略、性能差异与面试手撕全解
数据结构·c++·面试
Irissgwe14 小时前
map/set/multimap/multiset 的底层逻辑与实现
数据结构·c++·算法·二叉树·stl·c·红黑树
IronMurphy14 小时前
【算法五十八】23. 合并 K 个升序链表
数据结构·算法·链表
noipp15 小时前
【无标题】
c语言·数据结构·c++·算法