码迷,mamicode.com
首页 > 其他好文 > 详细

双向链表

时间:2017-09-22 16:10:08      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:内容   init   include   insert   lin   out   clu   输出   ext   

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);

}

 

双向链表

标签:内容   init   include   insert   lin   out   clu   输出   ext   

原文地址:http://www.cnblogs.com/paulversion/p/7575351.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!