双向链表

Posted paulversion

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了双向链表相关的知识,希望对你有一定的参考价值。

typeStructDefine.h

typedef struct DuLNode {
int data;
struct DuLNode *prior;
struct DuLNode *next;

}DuLNode,*DuLinkList;

typedef int Status;

//初始化一个空指针
Status ListInit_Dul(DuLinkList *L);
//向双向链表中插入元素
Status ListInsert_DuL(DuLinkList *L,int i,int e);

//在双向链表中删除元素
Status ListDelete_DuL(DuLinkList *L,int i);

//输出双向链表中的内容
Status OutPut_DuLinkList(DuLinkList L);

 

FunctionRealize.c

 

#include "TypeStructDefine.h"
#include "stdlib.h"
#include "stdio.h"


//初始化一个空的双向链表
Status ListInit_Dul(DuLinkList *L) {

*L = (DuLinkList)malloc(sizeof(DuLNode));
(*L)->next = NULL;
}


//双向链表在第i个位置插入元素
Status ListInsert_DuL(DuLinkList *L, int i, int e) {

DuLinkList p,node;

//插入时需要判断是否超出界限
node = (DuLinkList*)malloc(sizeof(DuLNode));
node->data = e;

p = *L;
int j = 0;
while (p&&j<i-1)
{
j++;
p = p->next;
}
node->next = p->next;
if (p->next != NULL) {
p->next->prior = node;
}
node->prior = p;
p->next = node;


}

//删除元素
Status ListDelete_DuL(DuLinkList *L, int i) {
DuLinkList p;

//插入时需要判断是否超出界限

p = *L;
int j = 0;
while (p&&j<i - 1)
{
j++;
p = p->next;
}
p->next = p->next->next;
p->next->prior = p;

}

Status OutPut_DuLinkList(DuLinkList L) {
DuLinkList p;
p = L->next;
while (p)
{
printf("对应的值为%d\n",p->data);
p = p->next;
}

}

 

 

DuLinkList.c

#include "stdio.h"
#include "stdlib.h"
#include "TypeStructDefine.h"

void main() {

//指针类型
DuLinkList L;

//初始化一个空的链表
ListInit_Dul(&L);

ListInsert_DuL(&L,1,1);
ListInsert_DuL(&L,2,2);
ListInsert_DuL(&L,3,3);
ListInsert_DuL(&L,2,4);

ListDelete_DuL(&L,2);

OutPut_DuLinkList(L);
//printf("输出链表的第一个值为%d\n",L->next->data);

}

 

以上是关于双向链表的主要内容,如果未能解决你的问题,请参考以下文章

数据结构(链表——双向链表的实现)

带头节点的双向链表

双向链表的原理与实现

数据结构之带头结点的循环双向链表详细图片+文字讲解

Python数据结构与算法(2.4)——双向链表

双向链表