双向链表需要定义一个结构体,结构体有3个属性
typedef struct __Node{
int data; 数据
struct __Node *pre; 指向前一个结点指针
struct __Node *next; 指向下一个结点指针
}Node;
其中 pre和next指针是嵌套定义。
一般链表定义一个头指针
Node *head;
指向链表第一个结点,如果链表为空的话,那么head == NULL。
双向链表一般分为init,insert, delete, search, destroy等几种操作
1、init
初始化:将头指针head置为NULL即可
2、insert
插入:这里我只实现了在表头位置插入新元素。在表头位置插入元素的话,需要注意区别处理空表和非空表的情况。
1)空表的话,因为有init过程,所以head为NULL,新元素的next指针指向head(NULL),同时设置新元素的pre指针为NULL即可。
2)非空表的话,需要设置以前的头结点元素的pre指针,因为头结点的pre指针都是NULL。其他和空表一样操作。
如果要实现在链表的指定位置插入的话,需要先遍历链表找到那个位置,然后再插入。
3、delete
删除:这里我实现了删除第一个元素和删除指定的元素。其中删除指定的元素需要查找。
4、search
查找:遍历链表进行查找即可
5、destroy
销毁:将每个结点开辟的内存分别释放,最后将头结点指针head置为NULL即可。
在以上操作过程中,要注意当链表非空时,一定要保证尾结点的next域为NULL,头结点的pre域为NULL,否则容易导致错误!
C语言实现代码如下:
输出如下
双向链表为空!
19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
遍历成功
成功删除第一个元素!
成功删除第一个元素!
17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
遍历成功
成功删除第一个元素!
删除查找中...
查找值为 10的元素成功
删除值为 10的元素成功
删除查找中...
查找值为 16的元素成功
成功删除第一个元素!
删除查找中...
查找值为 0的元素成功
删除最后一个元素成功
15 14 13 12 11 9 8 7 6 5 4 3 2 1
遍历成功
97 98 99 100 15 14 13 12 11 9 8 7 6 5 4 3 2 1
遍历成功
删除查找中...
查找值为 99的元素成功
删除值为 99的元素成功
删除查找中...
查找值为 97的元素成功
成功删除第一个元素!
删除查找中...
查找值为 96的元素失败
删除值为 96的元素失败
98 100 15 14 13 12 11 9 8 7 6 5 4 3 2 1
遍历成功
开始销毁链表...
销毁成功!
Press any key to continue