双链表基础——定义&模板&例题&插入&删除

双链表基础——定义&模板&例题&插入&删除

双链表是单链表的加强版——它可以从前往后遍历,也可以从后往前遍历,而且在遍历的过程中,当前结点的指针可以选择指向前面的结点也可以选择指向后面的结点,这使得它十分地灵活;

我们今天来看一道acwing的题目;

双链表定义&模板

​ 双链表就是单链表加上一个前驱指针域;

还记得单链表的数据结构是说明样子的吗:

请添加图片描述

而这是双链表:
请添加图片描述

单链表 = 数据域 + 后驱指针域

struct nodes{
nodes* next;
int data;
};

双链表 = 前驱指针域 + 数据域 + 后驱指针域

struct nodes{
nodes* pre;
nodes* next;
int data;
};

单链表设置了一个头结点,方便我们从头结点开始遍历数据,设置了一个入口;

双链表设置了一个头结点和一个尾结点,我们可以从头开始遍历数据,或者从尾部开始遍历数据;

这里提供一个y总的双链表模板,来自acwing网站

// e[]表示节点的值,l[]表示节点的左指针,r[]表示节点的右指针,idx表示当前用到了哪个节点
int e[N], l[N], r[N], idx;

// 初始化
void init()
{
    //0是左端点,1是右端点
    r[0] = 1, l[1] = 0;
    idx = 2;
}

// 在节点a的右边插入一个数x
void insert(int a, int x)
{
    e[idx] = x;
    l[idx] = a, r[idx] = r[a];
    l[r[a]] = idx, r[a] = idx ++ ;
}

// 删除节点a
void remove(int a)
{
    l[r[a]] = l[a];
    r[l[a]] = r[a];
}

作者:yxc
链接:https://www.acwing.com/blog/content/404/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

双链表例题

827. 双链表 - AcWing题库

题解如下:

	#include<iostream>
	using namespace std;
	const int N = 1e5 + 10;
	int m;
	int e[N],l[N],r[N];
	int idx;//idx是代表当前这个位置;
	
	//双链表初始化
	void inti(){
	l[1] = 0 , r[0] = 1;//将头结点和尾结点连起来
	idx = 2 ; //2是新的点,因为我们将依次开辟空间放入更多的结点,我们既然已经用过0和1了,自然就轮到2了 
	} 
	
	// 在第k个点的右边插入一个x
	void add(int k, int x){
	e[idx] = x;
	l[idx] = k;
	r[idx] = r[k];
	l[r[k]] = idx ; 
	r[k] = idx;
	idx ++ ;
	} 
	
	void remove(int k){
	r[l[k]] = r[k];
	l[r[k]] = l[k];
	}
	
	int main(){
	int t;
	
	ios::sync_with_stdio(false);
	
	cin>>t;
	
	inti();
	
	while(t--){
	
	string op;
	cin>>op;
	int k , x ;
	if(op == "R" ){
	cin>>x;
	add(l[1],x);
	
	}
	else if(op == "L"){
	cin >> x;
	add(0 , x); 
	}
	else if(op == "D"){
	cin >> k ;
	remove( k + 1 );
	}
	else if(op == "IL"){
	cin>> k >> x;
	add(l[k + 1] , x);
	}
	else
	{
	cin >> k >> x;
	add( k + 1 , x ); 
	}
	
	}
	for(int i = r[0] ; i != 1 ; i = r[i] )cout<<e[i]<<" ";
	return 0;
	}

插入操作

请添加图片描述

插入操作非常讲究顺序:

先将当前的结点idx 向左 连接至结点k

其次将当前的结点idx 向右 连接至结点k右边的结点r[k];

然后是将结点k右边的结点r[k] 向左 连接至当前结点idx

最后将结点k 向右 连接至当前结点idx

// 在第k个点的右边插入一个x
void add(int k, int x){
e[idx] = x;
l[idx] = k;
r[idx] = r[k];
l[r[k]] = idx ; 
r[k] = idx;
idx ++ ;
} 

删除操作

请添加图片描述

void remove(int k){
r[l[k]] = r[k];
l[r[k]] = l[k];
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 非常抱歉,我是一名语言模型AI,无法直接回答问题。但是,我可以告诉您,C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植等特点,被广泛应用于系统软件、嵌入式系统、游戏开发等领域。经典200道实例是一本C语言编程实例集合,包含基础例题100道和进阶例题100道,适合初学者和进阶者学习和练习。如果您有具体的问题或需求,欢迎随时向我提问。 ### 回答2: C语言——经典200道实例是一本讲述C语言编程实例的书籍,它共包含基础例题100道和进阶例题100道。这些实例从简单到复杂、从基础到深入地介绍了C语言的各个方面。 基础例题100道主要介绍了C语言的基本语法、数据类型、流程控制、函数等知识点。这些实例中涵盖了最基本的编程技巧和逻辑思考方式,让读者可以逐步了解C语言的编程思路。例如,第4题要求编写程序,在屏幕上输出Hello, world!,这是C语言中最基本的程序实例。而第28题则要求编写程序,判断输入的数字是奇数还是偶数,是典型的流程控制程序。 进阶例题100道则涵盖了更加复杂的编程技巧和算法思想。这些实例中有些需要用到高级数据类型,例如指针和结构体,有些需要用到高级算法思想,例如递归和动态规划等。例如,第145题要求编写程序,实现字符串的逆序输出和复制,这需要用到指针和字符串函数。而第190题则要求编写程序,使用动态规划算法解决斐波那契数列问题,是典型的算法实例。 总的来说,C语言——经典200道实例是一本非常实用的C语言编程教材,它通过大量实例的介绍,让读者可以掌握C语言的基础知识和进阶技巧,从而能够熟练地运用C语言进行编程。无论是初学者还是有一定C语言编程经验的读者,都可以受益于这本书的学习。 ### 回答3: C语言是计算机科学教育中的重要基础语言,也是编程语言入门的首选。而“c语言——经典200道实例【基础例题100道——进阶例题100道】”这本书对于c语言初学者来说是一本极好的练习题集。它包含了100个基础例题和100个进阶例题,涵盖了c语言中的各种语法和语义知识,可以很好地帮助初学者快速提高编程能力。 在基础例题方面,这本书从最基本的数据类型、运算符等知识点开始,逐步深入地讲解了if语句、for循环、while循环、数组、字符串、函数等c语言常用语法和概念,其中的例题非常全面、典型且有针对性,可以让初学者更好地掌握语法和提高编程能力。 在进阶例题方面,这本书则进一步提高了编程难度和思维难度,更加侧重于深入理解c语言的编程思想和实践问题。比如,它包括了递归、指针、二维数组、动态内存分配等比较复杂的概念和应用,这些内容可以更加全面地帮助初学者掌握基础知识,并且在实践中提高自己的思维能力。 总的来说,“c语言——经典200道实例【基础例题100道——进阶例题100道】”这本书是一本非常优秀而且实用的书籍,它能够帮助初学者快速提高编程能力,掌握c语言的核心概念,并且为其未来在计算机语言和编程领域的发展打下坚实的基础。如果你想要对c语言进行系统的学习和实践,这本书是一个非常好的起点和参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值