数据结构链表的头插法建立、删除、计数、查找、输出

本文详细讲解了如何使用头插法建立链表,包括插入新节点、删除指定节点、计算链表长度、查找特定元素以及遍历输出链表的所有元素。通过实例演示,深入理解链表这一基础数据结构的操作。
摘要由CSDN通过智能技术生成
#define _CRT_SECURE_NO_WARNINGS
#include "LIST.h"
#include <stdio.h>
#include <stdlib.h>


void InitLinkLinst(List *L)
{
	*L = NULL;
}

void PushFront(List* L, int d)//头插
{
	Node* cur = *L;
	Node *p = (Node*)malloc(sizeof(Node));//动态开辟一块内存用来存放插入的元素
	memset(p, 0, sizeof(Node));
	p->data = d;
	p->next = NULL;
	p->next = *L;//将插入元素的next指针指向原链表的头结点
	*L = p;//链表重置后的新的头结点
}

void PopFront(List* L)//删除
{
	Node* cur = *L;
	if (cur == NULL)//空链表
	{
		return;
	}
	else           //非空链表
	{
		*L = cur->next;//链表重置后的新的头结点
		free(cur);
		cur = NULL;
	}
}

pNode Find(List* L, int d)//查找元素,若找到了返回位置,没找到返回空指针
{
	Node* cur = *L;
	while (cur != NULL)
	{
		if (cur->data == d)
		{
			printf("找到了!\n");
			return;
		}
		else
		{
			cur = cur->next;
		}
	}
	return NULL;
}

int Count(List L)//计数操作
{
	Node* cur = L;
	int count = 0;
	for (; cur != NULL; cur &
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值