循环双链表(C语言)
2019-06-26 本文已影响3人
PersisThd
1、头文件circle_doublelist.h
#include <stdio.h>
typedef struct Node
{
int data;
struct Node* next;
struct Node* prior;
}Node;
typedef struct cir_doublelist
{
Node header;
int length;
}cir_doublelist;
void InitList(cir_doublelist*);
int ListEmpty(cir_doublelist*);
int ListLength(cir_doublelist*);
Node* CreateList(cir_doublelist*, int);
void ListTest(cir_doublelist*, int);
void ListTest_Reverse(cir_doublelist*, int);
void ListDelete(cir_doublelist*, int, int*);
void ListInsert(cir_doublelist*, int, int);
void GetElem(cir_doublelist*, int, int*);
void ClearList(cir_doublelist*);
void DestroyList(cir_doublelist*);
2、相关操作函数文件circle_doublelist.c
#include <stdio.h>
#include <stdlib.h>
#include "circle_doublelist.h"
void InitList(cir_doublelist* L)
{
L->header.next = NULL;
L->header.next = NULL;
L->length = 0;
}
int ListEmpty(cir_doublelist* L)
{
if(L->length == 0)
return 1;
return 0;
}
int ListLength(cir_doublelist* L)
{
return L->length;
}
Node* CreateList(cir_doublelist* L, int n)
{
if(n <= 0)
{
printf("输入的链表长度非法!");
return NULL;
}
Node* pCur = &L->header;
Node* head = &L->header;
int i = 0;
for(i = 0; i < n; i++)
{
Node* pNew = (Node*)malloc(sizeof(Node));
printf("请输入链表中位置%d处的值:\n", i);
scanf("%d", &pNew->data);
if(i == 0)
{
pCur->next = pNew;
pCur = pCur->next;
L->length++;
}
else
{
pCur->next = pNew;
pNew->prior = pCur;
pNew->next = head->next;
head->next->prior = pNew;
pCur = pCur->next;
L->length++;
}
}
return head;
}
void ListTest(cir_doublelist* L, int n)
{
if(L->length == 0)
{
printf("当前链表为空链表!");
return;
}
printf("*****循环双链表顺序遍历测试*****\n");
int i = 0;
Node* pCur = &L->header;
for(i = 0; i < n; i++)
{
pCur = pCur->next;
printf("The value is: %d\n", pCur->data);
}
printf("\n");
}
void ListTest_Reverse(cir_doublelist* L, int n)
{
if(L->length == 0)
{
printf("当前链表为空链表!");
return;
}
printf("*****循环双链表逆序遍历测试*****\n");
int i = 0;
Node* pCur = &L->header;
for(i = 0; i < L->length; i++)
{
pCur = pCur->next;
}
for(i = 0; i < n; i++)
{
printf("The value is: %d\n", pCur->data);
pCur = pCur->prior;
}
printf("\n");
}
void ListDelete(cir_doublelist* L, int pos, int* e)
{
if(pos < 0 || pos >= L->length)
{
printf("插入的位置非法!\n");
return;
}
if(L->length == 0)
{
printf("链表为空,无法删除!");
}
int i = 0;
Node* pCur = &L->header;
Node* head = &L->header; //始终指向头结点
Node* tail = &L->header; //始终指向最后一个结点
for(i = 0; i < L->length; i++)
{
tail = tail->next;
}
for(i = 0; i < pos; i++)
{
pCur = pCur->next;
}
Node* pDel = (Node*)malloc(sizeof(Node));
if(pos == 0)
{
pDel = pCur->next;
*e = pDel->data;
pCur->next = pDel->next;
pDel->next->prior = tail;
tail->next = pDel->next;
free(pDel);
L->length--;
return;
}
if(pos == L->length - 1)
{
pDel = pCur->next;
*e = pDel->data;
pCur->next = head->next;
head->next->prior = pCur;
tail = pCur; //删除最后一个结点前记得更新尾指针
free(pDel);
L->length--;
return;
}
pDel = pCur->next;
pCur->next = pDel->next;
pDel->next->prior = pCur;
free(pDel);
L->length--;
}
void ListInsert(cir_doublelist* L, int pos, int e)
{
if(pos < 0 || pos > L->length)
{
printf("插入位置非法!");
return;
}
int i = 0;
Node* pCur = &L->header;
Node* head = &L->header;
Node* tail = &L->header;
for(i = 0; i < L->length; i++)
{
tail = tail->next;
}
for(i = 0; i < pos; i++)
{
pCur = pCur->next;
}
Node* pNew = (Node*)malloc(sizeof(pNew));
pNew->data = e;
if(pos == 0)
{
pNew->next = pCur->next;
pCur->next->prior = pNew;
pCur->next = pNew;
pNew->prior = tail;
tail->next = pNew;
L->length++;
return;
}
if(pos == L->length)
{
pCur->next = pNew;
pNew->prior = pCur;
pNew->next = head->next;
head->next->prior = pNew;
tail = pNew; //在最后插入时记得更新尾指针
L->length++;
return;
}
pNew->next = pCur->next;
pCur->next->prior = pNew;
pNew->prior = pCur;
pCur->next = pNew;
L->length++;
}
void GetElem(cir_doublelist* L, int pos, int* e)
{
if(pos < 0 || pos >= L->length)
{
printf("查询位置非法!");
}
if(L->length == 0)
{
printf("链表为空链表");
}
int i = 0;
Node* pCur = &L->header;
for(i = 0; i <= pos; i++)
{
pCur = pCur->next;
}
*e = pCur->data;
}
void ClearList(cir_doublelist* L)
{
while(L->length)
{
int tmp;
ListDelete(L, 0, &tmp);
}
}
void DestroyList(cir_doublelist* L)
{
ClearList(L);
free(L);
printf("当前链表已销毁!");
}
3、主函数main.c
#include <stdio.h>
#include <stdlib.h>
#include "circle_doublelist.h"
int main()
{
cir_doublelist ls;
InitList(&ls);
printf("请输入链表的长度:");
int len;
scanf("%d", &len);
CreateList(&ls, len);
ListTest(&ls, 2 * ls.length);
ListTest_Reverse(&ls, 2 * ls.length);
int tmp;
ListDelete(&ls, 0, &tmp);
ListTest(&ls, 2 * ls.length);
ListDelete(&ls, 1, &tmp);
ListTest(&ls, 2 * ls.length);
ListDelete(&ls, ls.length-1, &tmp);
ListTest(&ls, 2 * ls.length);
ListInsert(&ls, ls.length, 5);
ListTest(&ls, 2 * ls.length);
ListInsert(&ls, 1, 3);
ListTest(&ls, 2 * ls.length);
ListInsert(&ls, 0, 1);
ListTest(&ls, 2 * ls.length);
GetElem(&ls, 0, &tmp);
printf("tmp = %d\n", tmp);
GetElem(&ls, ls.length-1, &tmp);
printf("tmp = %d\n", tmp);
ClearList(&ls);
printf("当前链表长度为:%d\n", ls.length);
DestroyList(&ls);
return 0;
}