前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Doubly Linked List

Doubly Linked List

作者头像
废江_小江
发布于 2022-09-05 06:32:50
发布于 2022-09-05 06:32:50
20700
代码可运行
举报
文章被收录于专栏:总栏目总栏目
运行总次数:0
代码可运行

Question

Your task is to implement a double linked list.

Write a program which performs the following operations:

insert x: insert an element with key x into the front of the list.

delete x: delete the first element which has the key of x from the list. If there is not such element, you need not do anything.

deleteFirst: delete the first element from the list.

deleteLast: delete the last element from the list.

Input

The input is given in the following format:

n

command1

command2

commandn

In the first line, the number of operations n is given. In the following n lines, the above mentioned operations are given in the following format:

insert x

delete x

deleteFirst

deleteLast

Output

Print all the element (key) in the list after the given operations. Two consequtive keys should be separated by a single space.

Constraints

The number of operations ≤ 2,000,000

The number of delete operations ≤ 20

0 ≤ value of a key ≤ 109

The number of elements in the list does not exceed 106

For a delete, deleteFirst or deleteLast operation, there is at least one element in the list.

Sample Input 1

7

insert 5

insert 2

insert 3

insert 1

delete 3

insert 6

delete 5

Sample Output 1

6 1 2

Sample Input 2

9

insert 5

insert 2

insert 3

insert 1

delete 3

insert 6

delete 5

deleteFirst

deleteLast

Sample Output 2

1

Meaning

写链表实现双向链表的操作

Solution

这题坑我了三四个小时,oj测试数据中的第四组删除一个根本就不存在的数据。所以代码只能ac前面三个测试。用的是教材上面的双向链表。后面经过一个大佬给我修改了一下bug,原本在deleem函数中是不能删除最后一个节点的。但是还是不能ac,很恶心,不想看这一题了。感觉弄了好久啥也没学到。

Coding

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//双链表基本运算算法(教材上的) 
#include <stdio.h>
#include <malloc.h>
#include<iostream>
using namespace std;
typedef int ElemType;
typedef struct DNode		//定义双链表结点类型
{
	ElemType data;
	struct DNode* prior;	//指向前驱结点
	struct DNode* next;		//指向后继结点
} DLinkNode;
void CreateListF(DLinkNode*& L, ElemType a[], int n)
//头插法建双链表
{
	DLinkNode* s;
	L = (DLinkNode*)malloc(sizeof(DLinkNode));  	//创建头结点
	L->prior = L->next = NULL;
	for (int i = 0; i < n; i++)
	{
		s = (DLinkNode*)malloc(sizeof(DLinkNode));//创建新结点
		s->data = a[i];
		s->next = L->next;			//将结点s插在原开始结点之前,头结点之后
		if (L->next != NULL) L->next->prior = s;
		L->next = s; s->prior = L;
	}
}
void CreateListR(DLinkNode*& L, ElemType a[], int n)
//尾插法建双链表
{
	DLinkNode* s, * r;
	L = (DLinkNode*)malloc(sizeof(DLinkNode));  	//创建头结点
	L->prior = L->next = NULL;
	r = L;					//r始终指向终端结点,开始时指向头结点
	for (int i = 0; i < n; i++)
	{
		s = (DLinkNode*)malloc(sizeof(DLinkNode));//创建新结点
		s->data = a[i];
		r->next = s; s->prior = r;	//将结点s插入结点r之后
		r = s;
	}
	r->next = NULL;				//尾结点next域置为NULL
}
void InitList(DLinkNode*& L)
{
	L = (DLinkNode*)malloc(sizeof(DLinkNode));  	//创建头结点
	L->prior = L->next = NULL;
}
void DestroyList(DLinkNode*& L)
{
	DLinkNode* pre = L, * p = pre->next;
	while (p != NULL)
	{
		free(pre);
		pre = p;
		p = pre->next;
	}
	free(pre);
}
bool ListEmpty(DLinkNode* L)
{
	return(L->next == NULL);
}
int ListLength(DLinkNode* L)
{
	DLinkNode* p = L;
	int i = 0;
	while (p->next != NULL)
	{
		i++;
		p = p->next;
	}
	return(i);
}
void DispList(DLinkNode* L)
{
	DLinkNode* p = L->next;
	printf("%d", p->data);
	p = p->next;
	while (p != NULL)
	{	
 
		printf(" %d", p->data);
		p = p->next;
	}
	printf("\n");
}
bool GetElem(DLinkNode* L, int i, ElemType& e)
{
	int j = 0;
	DLinkNode* p = L;
	if (i <= 0) return false;		//i错误返回假
	while (j < i && p != NULL)
	{
		j++;
		p = p->next;
	}
	if (p == NULL)
		return false;
	else
	{
		e = p->data;
		return true;
	}
}
int LocateElem(DLinkNode* L, ElemType e)
{
	int n = 1;
	DLinkNode* p = L->next;
	while (p != NULL && p->data != e)
	{
		n++;
		p = p->next;
	}
	if (p == NULL)
		return(0);
	else
		return(n);
}
bool ListInsert(DLinkNode*& L, int i, ElemType e)
{
	int j = 0;
	DLinkNode* p = L, * s;
	if (i <= 0) return false;		//i错误返回假
	while (j < i - 1 && p != NULL)
	{
		j++;
		p = p->next;
	}
	if (p == NULL)				//未找到第i-1个结点
		return false;
	else						//找到第i-1个结点p
	{
		s = (DLinkNode*)malloc(sizeof(DLinkNode));	//创建新结点s
		s->data = e;
		s->next = p->next;		//将结点s插入到结点p之后
		if (p->next != NULL)
			p->next->prior = s;
		s->prior = p;
		p->next = s;
		return true;
	}
}
bool ListDelete(DLinkNode*& L, int i, ElemType& e)
{
	int j = 0;
	DLinkNode* p = L, * q;
	if (i <= 0) return false;		//i错误返回假
	while (j < i - 1 && p != NULL)
	{
		j++;
		p = p->next;
	}
	if (p == NULL)				//未找到第i-1个结点
		return false;
	else						//找到第i-1个结点p
	{
		q = p->next;				//q指向要删除的结点
		if (q == NULL)
			return false;		//不存在第i个结点
		e = q->data;
		p->next = q->next;		//从单链表中删除*q结点
		if (p->next != NULL) p->next->prior = p;
		free(q);				//释放q结点
		return true;
	}
}
//在循环双链表L中删除第一个值为x的结点。
bool delelem(DLinkNode*& L, ElemType x)
{
	//DLinkNode* p = L->next;
	//while (p != L && p->data != x)
	//	p = p->next;
	//if (p != L)						//找到第一个元素值为x的结点
	//{
	//	p->next->prior = p->prior;	//删除结点*p
	//	p->prior->next = p->next;
	//	free(p);
	//	return true;
	//}
	//else
	//	return false;
 
	//下面的某个大佬写的
	DLinkNode* p = L;
	while (p->next->data != x && p->next != NULL)p = p->next;
	if (p->next == NULL)return false;
	else {
		DLinkNode* wait_free = p->next;
		p->next = p->next->next;
		free(wait_free);
		return true;
	}
}
int main() {
	DLinkNode* dl;
	InitList(dl);
	int n;
	scanf("%d",&n);
	//cin >> n;
	char name[20];
	ElemType e;
	for (int i = 0; i < n; i++) {
				scanf("%s",&name);
				
		cin >> name;
		if (name[0] == 'i') {
			scanf("%d", &e);
			//cin >> e;
			ListInsert(dl, 1, e);
		}
		else if (name[6] == 'F') {
			ListDelete(dl, 1, e);
		}
		else if (name[6] == 'L') {
			ListDelete(dl, ListLength(dl), e);
		}
		else {
			//cin >> e;
			scanf("%d", &e);
			delelem(dl, e);
		}
	}
	DispList(dl);
}

Summary

废江博客 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权

转载请注明原文链接:Doubly Linked List

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-04-05),如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【优秀题解】问题 1678: 算法2-18~2-19:双向循环链表
第一步:(这一步千万不要倒过来 否则会出错)先把p->next元素(用x 元素代替),
编程范 源代码公司
2018/08/16
6440
【优秀题解】问题 1678: 算法2-18~2-19:双向循环链表
数据结构-线性表链式存储
姓王者
2024/11/09
1070
数据结构(4)双链表,循环链表,静态链表
双链表和单链表的区别就是,一个结点除了有指向后一个结点的指针域,还有一个指向前一个结点的指针域,所以建表的代码为:
mumumu
2022/12/26
4420
数据结构(4)双链表,循环链表,静态链表
线性表(链式存储结构)
废江博客 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 转载请注明原文链接:线性表(链式存储结构)
废江_小江
2022/09/05
7950
【数据结构】循环链表(circular linked list) && 双向链表(doubly linked list)
前面介绍了单链表,相信大家还记得相关的概念。其实循环链表跟单链表也没有差别很多,只是在某些细节上的处理方式会稍稍不同。
短短的路走走停停
2019/05/13
2.5K0
【数据结构】循环链表(circular linked list) && 双向链表(doubly linked list)
xmuC语言程序实践week 3 大作业
置pre now双指针,找到要删的元素pre指向now后一个链表元素地址,相当于直接将要删除元素架空
glm233
2020/09/28
2130
【数据结构系列】双向链表
上一篇文章中我们说到单链表,然后最后有一道习题,不知道大家有没有做出来,为了照顾一些还不太会的同学,这里专门对这道题进行一个简单的讲解,先来看看原题内容:
wangweijun
2020/02/14
5650
《王道》数据结构笔记整理2022级_数据结构笔记整理
1.数据:数据是信息的载体,是描述客观事物属性的数、字符以及所有能输入到计算机中并被程序识别和处理的符号的集合。
全栈程序员站长
2022/09/22
3.1K0
《王道》数据结构笔记整理2022级_数据结构笔记整理
《大话数据结构》线性表代码总结
//线性表存储的结构代码 #include<stdio.h> #include<stdlib.h> #include<time.h> #define MAXSIZE 1000//静态链表部分的 #define MAX_SIZE 20//最大长度 #define OK 1 #define ERROR 0 #define TRUE 1 #define FALSE 0 //线性表顺序存储结构 //自定义的类型 以描述返回状态值 typedef int Status;//Status是函数的类型,其值是函数结果的状
半生瓜的blog
2023/05/12
1980
《大话数据结构》线性表代码总结
C语言双链表,循环链表,静态链表讲解(王道版)
在单链表中,每个元素都附加了一个指针域,指向下一个元素的存储位置。在双向链表中,每个元素都附加了两个指针域,分别指向前驱节点和后继节点。
莫浅子
2022/11/18
1.1K0
C语言双链表,循环链表,静态链表讲解(王道版)
双向链表
双向链表       在线性链式存储结构的结点中只有一个指示直接后继的指针域,由此,从某个结点出发只能顺指针往后寻查其他结点。若要寻查结点的直接前趋,则需从表头指针出 发。换句话说,在单链表中,Ne
猿人谷
2018/01/17
1.1K0
双向链表
【数据结构】C语言实现双链表的基本操作
经过前面几个篇章的内容分享,相信大家对顺序表和单链表的基本操作都已经熟练掌握了。今天咱们将继续分享线性表的链式存储的第二种形式——双链表。在今天的内容中,咱们将介绍双链表的创建以及一些基本操作,接下来跟我一起来看看吧!
蒙奇D索隆
2023/12/30
5020
【数据结构】C语言实现双链表的基本操作
单链表反转的分析及实现
我先画一个单链表,这个单链表有4个元素。我的思路就是,每次把第二个元素提到最前面来。比如下面是第一次交换,我们先让头结点的next域指向结点a2,再让结点a1的next域指向结点a3,最后将结点a2的
猿人谷
2018/01/17
2.3K0
单链表反转的分析及实现
两个非递增的有序链表的合并
已知两个带头结点的非递增有序的单链表A和B,设计算法将两个单链表合并成一个非递增有序的单链表C.要求单链表C仍使用原来两个链表的存储空间
别团等shy哥发育
2023/02/27
8840
C语言单链表实现初始化、创建、增、删、查等基本操作(详细)
LNode *L ;             //声明一个指向单链表第一个结点的指针 (强调这是一个结点用LNode*)
莫浅子
2022/11/18
1.7K0
单链表的算法
静默虚空
2018/01/05
6900
2024重生之回溯数据结构与算法系列学习【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
开放式问题的解题思路: 问题: 请描述顺序表和链表的bla bla bla…实现线性表时,用顺序表还是链表好? 答案:
盛透侧视攻城狮
2024/10/22
1030
2024重生之回溯数据结构与算法系列学习【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构(3)单链表
前前后后看了四天左右吧,一方面把单链表过了几遍,另一方面也补全了一些基础,诸如 &引用,结构体指针,封装 等等内容,感觉难点不是代码怎么敲,而是要想明白每个操作的逻辑以及一些容易忽略的边界条件,为什么要有这些边界条件,没有这个条件会影响到哪些特殊情况?想明白这些很重要。
mumumu
2022/12/26
2740
数据结构(3)单链表
链式存储
#define TRUE 1 #define ERROR 0 #define MAX_SIZE 100 #define OK 1 /**链式存储 * 1、节点:数据域,指针域组成一个节点 * 2、链表:n个节点由指针链组成一个链表 * 3、单链表、双链表、循环链表 * * 4、不带头结点 * 5、带头结点 * 6、顺序存取 * */ class LianList{ typedef struct{ char num[8]; char name[8];
lascyb
2022/01/13
4290
单链表
线性表的链式表示和实现       线性表的链式存储结构的特点是用一组任意的存储单元存储线性表的数据元素(这组存储单元可以是连续的,也可以使不连续的)。因此,为了表示每个数据元素ai与其直接后继数据元素ai+1之间的逻辑关系对数据元素ai来说,除了存储其本身的信息之外,还需存储一个指示其直接后继的信息(即直接后继的存储位置)。这两部分信息组成数据元素ai的存储映像,称为结点。      结点包括两个域:其中存储数据元素信息的域称为数据域;存储直接后继存储位置的域称为指针域。指针域中存储的信息称做指针或链。n
猿人谷
2018/01/17
9870
单链表
相关推荐
【优秀题解】问题 1678: 算法2-18~2-19:双向循环链表
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验