单向链表基本操作

本文介绍了如何使用C语言实现链表的基本操作,包括初始化链表,按值插入新节点,删除指定值的节点,遍历链表以及销毁和清空整个链表。每个操作都提供了详细的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

初始化链表

插入

删除

遍历

销毁

清空


初始化链表

代码:

struct LinkNode* Init_LinkList() {
	struct LinkNode* head = (struct LinkNode*)malloc(sizeof(struct LinkNode));
	head->data = -1;
	head->next = NULL;
	// 尾部指针
	struct LinkNode* pRear = head;
	int val = -1;
	while (true) {
		printf("输入插入的数据:\n");
		scanf("%d", &val);
		if (val == -1) {
			break;
		}
		// 先创建新节点
		struct LinkNode* newnode = (struct LinkNode*)malloc(sizeof(struct LinkNode));
		newnode->data = val;
		newnode->next = NULL;
		// 新节点插入到链表
		pRear->next = newnode;

		// 更新尾部指针指向
		pRear = newnode;
	}
	return head;
}
插入

在值为oldval的位置插入一个新的数据 

代码: 

void InsertByValue_LinkList(struct LinkNode* head, int oldval, int newval) {
	if (head == NULL) {
		return;
	}
	// 两个辅助指针变量
	struct LinkNode* pPrev = head;
	struct LinkNode* pCurrent = pPrev->next;
	while (pCurrent != NULL) {
		if (pCurrent->data == oldval) {
			break;
		}
		pPrev = pCurrent;
		pCurrent = pCurrent->next;
	}

	// 先创建新节点
	struct LinkNode* newnode = (struct LinkNode*)malloc(sizeof(struct LinkNode));
	newnode->data = newval;
	newnode->next = NULL;

	// 新节点插入到链表中
	newnode->next = pCurrent;
	pPrev->next = newnode;

}
删除

删除值为val的节点 

代码:

void RemoveByValue_LinkList(struct LinkNode* head, int delValue) {
	
	if (head == NULL) {
		return;
	}
	// 两个辅助指针变量
	struct LinkNode* pPrev = head;
	struct LinkNode* pCurrent = pPrev->next;

	while (pCurrent != NULL) {
		if (pCurrent->data == delValue) {
			break;
		}
		// 移动两个辅助指针
		pPrev = pCurrent;
		pCurrent = pCurrent->next;
	}

	if (pCurrent == NULL) {
		return;
	}

	// 重新建立待删除节点的前驱和后继节点的关系
	pPrev->next = pCurrent->next;
	// 释放删除节点内存
	free(pCurrent);
	pCurrent = NULL;
}
遍历
void Foreach_LinkList(struct LinkNode* head) {
	if (head == NULL) {
		return NULL;
	}

	// 辅助指针变量
	struct LinkNode* pCurrent = head->next;
	while (pCurrent != NULL)
	{
		printf("%d ", pCurrent->data);
		pCurrent = pCurrent->next;
	}

}
销毁
void Destroy_LinkList(struct LinkNode* head) {
	if (NULL == head) {
		return;
	}

	// 辅助指针变量
	struct LinkNode* pCurrent = head;
	while (pCurrent != NULL) {
		// 先保存下当前节点的下一个节点地址
		struct LinkNode* pNext = pCurrent->next;

		// 释放当前节点内存
		printf("%d节点被销毁!", pCurrent->data);
		free(pCurrent);
		
		// 指针向后移动
		pCurrent = pNext; 
	}
}
清空
void Clear_LinkList(struct LinkNode* head) {
	if (head == NULL) {
		return;
	}

	// 辅助指针变量
	struct LinkNode* pCurrent = head->next;
	while (pCurrent != NULL) {
		// 先保存下当前节点的下一个节点地址
		struct LinkNode* pNext = pCurrent->next;

		// 释放当前节点内存
		free(pCurrent);

		// pCurrent指向下一个节点
		pCurrent = pNext;
	}
	head->next = NULL;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Wu小燕呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值