朱有鹏C语言高级---4.9.9--双链表--引入和实现(9)

朱有鹏C语言高级---4.9.9--双链表--引入和实现(9)

单链表的局限性

(1)单链表是对数组的一个扩展,解决了数组的大小比较死板不容易扩展的问题。使用堆内存来存储数据,将数据分散到各个节点之间,其各个节点在内存中可以不相连,节点之间通过指针进行单向连接。链表中的各个节点内存不相连,有利于利用碎片化的内存。

(2)单链表各个节点之间只由一个指针单向连接,这样实现有一些局限性。局限性主要体现在单链表只能经由指针单向移动(一旦指针移动过某个节点就无法再回来,如果要再次操作这个节点,除非从头指针开始再次遍历一次),因此单链表的某些操作就比较麻烦(算法比较局限)。回忆之前单链表的所有操作(插入,删除节点,遍历,从单链表中取某个节点的数。。。),因为单链表的单向移动性导致了不少麻烦。

总结:单链表的单向移动性导致我们在操作单链表时,当前节点只能向后移动不能向前移动,因此不自由,不利于解决更复杂的算法。

解决思路:

单链表的节点 = 有效数据 + 指针(指针指向后一个节点)

双向链表的节点 = 有效数据 + 2个指针(一个指向后一个节点,另一个指向前一个节点)

双链表的封装和编程实现

#include <stdio.h>

//双链表的节点
struct node
{
	int data;		//有效数据
	struct node *pPrev;	//前向指针,指向前一个节点
	struct node *pNext;	//后向指针,指向后一个节点
};

struct node *create_node(int data)
{
	struct node *p = (struct node *)malloc(sizeof(struct node));
	if (NULL == p)
	{
		printf("malloc error.\n");
		return NULL;
	}
	p->data = data;
	p->pPrev = NULL;
	p->pNext = NULL;	//默认创建的节点前向和后向指针都指向NULL

	return p;
}

int main(void)
{
	struct node *pHeader = create_node(0);	//头指针指向头节点	

	return 0;
}

猜你喜欢

转载自blog.csdn.net/xiaodingqq/article/details/83148782