C32.【C++ Cont】静态实现双向链表及STL库的list

目录

1.知识回顾

2.静态实现演示图

3.静态实现代码

1.初始双向链表

2.头插

3.遍历链表

4.查找某个值

4.任意位置之后插入元素

5.任意位置之前插入元素

6.删除任意位置的元素

4.STL库的list


1.知识回顾

96.【C语言】数据结构之双向链表的初始化,尾插,打印和尾删
97.【C语言】数据结构之双向链表的头插,头删,查找,中间插入,中间删除和销毁函数

上述文章均为动态实现双向链表,由于竞赛中追求运行速度快,因此不会动态实现双向链表,本文介绍静态实现双向链表

2.静态实现演示图

由于每一个结点要存储三个信息,因此静态实现使用三个数组:数值数组val,前驱数组prev,后继数组next,三个数组中同一个下标位置的元素打包成一个节点,如下图所框的(head指向头节点)

注:这里实现的双向链表为不循环的

将上方图改成逻辑结构再画图

3.静态实现代码

1.初始双向链表

cpp 复制代码
	const int N=1e5+10;
    //一开始prev数组和next数组元素值都为-1(无效下标),为空链表
    int prev[N]=-1; 
	int val[N];
	int next[N]=-1;
	//初始情况head和id都指向哨兵位结点 
	int head=0;
	int id=0;

2.头插

先保存新数据的值,再修改next和prev数组

只要①指针最后修改即可

cpp 复制代码
	void push_front(int data)
	{
		val[++id]=data;
		next[id]=next[head];
		prev[next[head]]=id;
		prev[id]=head;
		next[head]=id;//确保next[head]最后被修改 
	}

3.遍历链表

只需要看next数组即可遍历

cpp 复制代码
	void print()
	{
		for (int i=next[head];i!=-1;i=next[i])
		{
			cout<<val[i]<<" ";
		}	
	} 

4.查找某个值

和打印逻辑一样,按链表的方式遍历,注意不能只查val数组,有些元素被**"删除"**了(即按链表的方式查不到),但仍然存在于val数组中

只需要看next数组,查找到data在链表中第一次出现的位置 ,此方法时间复杂度为

cpp 复制代码
	void find(int data)
	{
		for (int i=next[head];i!=-1;i=next[i])
		{
			if (val[i]==data)
			{
				cout<<data<<"的下标为"<<i;
				return; 
			}
		}
		cout<<"未找到";
	}

如果使用标记数组mp优化(哈希表),直接return mpx,时间复杂度,但此方法有局限

4.任意位置之后插入元素

设在任意位置pos之后插入元素data,本质上和头插操作一样.,只要最后修改pos的后继指针即可

cpp 复制代码
	void insert_after(int pos,int data)
	{
		val[++id]=data;
		next[id]=next[pos];
		prev[next[pos]]=id;
		prev[id]=pos;
		next[pos]=id;//确保next[pos]最后被修改 
	}

5.任意位置之前插入元素

设在任意位置pos之前插入元素data,本质上和头插操作一样.,只要最后修改pos的前驱指针即可

cpp 复制代码
	void insert_before(int pos,int data)
	{
		val[++id]=data;
		next[prev[pos]]=id;
		prev[id]=prev[pos];
		next[id]]=pos;
		prev[pos]=id;//确保prev[pos]最后被修改 
	}

6.删除任意位置的元素

修改两个指针即可

cpp 复制代码
	void erase(int pos)
	{
		prev[next[pos]]=prev[pos];
		next[prev[pos]]=next[pos];
	}

4.STL库的list

提醒:list 的底层就是动态实现的双向循环链表,增删会涉及new和delete,执行速度慢,竞赛中不建议使用

初始化list: list<++任意++数据类型> 名称

cpp 复制代码
list<int> l;

头插: l.push_front 尾插: l.push_back 头删: l.pop_front 尾删: l.pop_back

相关推荐
guygg883 分钟前
人行走作用下板的振动响应 MATLAB 仿真
开发语言·matlab
小二·24 分钟前
Next.js 15 全栈开发实战
开发语言·javascript·ecmascript
fox_lht26 分钟前
15.3.改进我们之前的输入、输出项目
开发语言·后端·学习·rust
汉克老师34 分钟前
GESP2026年3月认证C++六级真题与解析(编程题1 选数)
c++·动态规划·线性dp·gesp六级·状态转移·选与不选
有点。41 分钟前
C++倍增法(练习题)
c++·算法
java1234_小锋1 小时前
LangChain4j 开发Java Agent智能体- 多模态支持
java·开发语言·langchain4j
凡人叶枫1 小时前
Effective C++ 条款23:宁以 non-member、non-friend 替换 member 函数
linux·开发语言·c++·嵌入式开发
张忠琳1 小时前
【Go 1.26.4】Golang Channel 深度解析
开发语言·后端·golang
盈建云系统1 小时前
B2B产品展示网站怎么做?从产品目录到询盘表单,企业获客页面搭建流程
开发语言·网站搭建·开发网站
不会C语言的男孩1 小时前
Linux 系统编程 · 第 4 章:文件属性与元数据
linux·c语言·开发语言