栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

链表的定义和初始化(C语言代码)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

链表的定义和初始化(C语言代码)

首先是链表的定义

typedef int ElemType;//指定结点中元素的类型
typedef struct LNode LNode;//修改类型别名让代码更简洁
typedef struct LNode *LinkList;
struct LNode //定义一个结点类
{
	ElemType data;
	struct LNode*next;
};

如果上面的定义还不够简洁的话
我们可以采用下面的这种方式

typedef int ElemType;
typedef struct LNode
{
	ElemType data;//每个结点存放一个数据元素
	struct LNode *next;//指针指向下一个结点
}LNode,*LinkList;

不带头结点的单链表

bool InitList(LinkList &L)
{
	L = NULL;//将头指针指向空,此时是一个空表
	return true;
}
//判断单链表是否为空
bool Empty(LinkList L)
{
	return(L == NULL);
}
void test()
{
	LinkList L;//声明一个指向单链表的指针
	InitList(L);
}


带头结点的单链表

//初始化一个空链表,,带头结点的情况
bool InitList(LinkList &L)
{
	L = ( LNode *) malloc ( sizeof ( LNode ) );//分配一个头结点
	if (L == NULL)
		return false;//内存不足 分配失败
	L->next = NULL;//头结点之后暂时还没有新结点
	return true;
}
//判断单链表是否为空
bool Empty(LinkList L)
{
		return (L->next == NULL)
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/867545.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号