链表的建立以及插值

本文介绍了链表的基础知识,包括链表的一致性、有序性、非连续性的特点,以及结点的构成。讲解了如何通过指针访问结构体成员,并列举了三种等价的访问方式。接着,详细阐述了创建链表和插入值的过程,包括按值插入和按序号插入。此外,还提供了一个实例展示了如何逆序排列链表,以及使用快慢指针判断链表是否有环的方法,鼓励读者参与讨论更多可能的解决方案。
摘要由CSDN通过智能技术生成

链表

是一大堆有序数据的结合
一致性,有序性,不一定连续
链表的每一个元素称为“结点”
结点=数据域+指针域
链表=一个头指针+n个结点
我们可以吧(*p).num改用p->num来代替,他表示p所值向的结构体变量中的num成员。
这有三种方法与之等价:
1,结构体变量。成员名
2.(*p).成员名
3. p->成员名
创建链表

#include<stdio.h>
    typedef struct _NODE
    {
    	int value;
    	struct _NODE * next;
    }NODE, *PNODE;       // PNODE是一个结构体类型的指针变量类型名
    int main()
{
	PNODE pHead = NULL;
	return 0;
}

然后开始对链表进行插入值

void InsertHead(PNODE * ppHead, int value)
{
	PNODE pNew = (PNODE)malloc(sizeof(NODE));//头插法
	pNew->value = value;

	pNew->next = *ppHead;
	*ppHead = pNew;
}

void InsertTail(PNODE * ppHead, int value)//尾插法
{
	if (NULL == *ppHead)
	{
		InsertHead(ppHead, value);
	}
	else
	{
		PNODE pPos = *ppHead;
		while (pPos->next != NULL)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值