【C语言-数据结构】单链表的定义

单链表的定义(实现)

比较顺序表和单链表的物理存储结构就能够清楚地发现二者的区别

用代码定义一个单链表

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

//要表示一个单链表时,只需声明一个头指针L,指向单链表的第一个结点
LNode* L;	//➡️ 强调这是一个结点
LinkList L; //➡️ 强调这是一个单链表
//以上两种声明方式都可以,建议使用第二种,代码可读性更强

单链表的初始化

不带头节点的单链表

c 复制代码
typedef struct LNode{
    ElemType data;
    struct LNode* next; 
}LNode, *LinkList;

bool InitList(LinkList* L){	//初始化一个空的单链表
    *L = NULL;	//空表,暂时没有任何结点,防止脏数据
    return true;
}

int main(){
    LinkList L; //声明一个指向单链表的指针
    InitList(&L);	//初始化一个空表
    //...
    return 0;
}

带头节点的单链表

c 复制代码
typedef struct LNode{
    ElemType data;
    struct LNode* next; 
}LNode, *LinkList;

//初始化一个单链表(带头节点)
bool InitList(LinkList* L){
    *L = (LNode*)malloc(sizeof(LNode));
    if(*L == NULL)
        return false;
    (*L)->next = NULL;
    return true;
}

int main(){
    LinkList L; //声明一个指向单链表的指针
    if (InitList(&L)) {  // 初始化一个空表,传递指针的地址
        printf("单链表初始化成功\n");
    } else {
        printf("单链表初始化失败\n");
    }
    //...
    return 0;
}

总结

不带头结点,写代码更麻烦

对第一个数据结点和后续数据结点的处理需要用不同的代码逻辑

对空表和非空表的处理需要用不同的代码逻辑

带头结点,写代码更方便


本文主要参考《王道计算机考研 数据结构》课程视频

相关推荐
繁花与尘埃3 小时前
HTML5简介与基本骨架(本文为个人学习笔记,内容整理自哔哩哔哩UP主【非学者勿扰】的公开课程。 > 所有知识点归属原作者,仅作非商业用途分享)
笔记·学习·html5
东方芷兰3 小时前
LLM 笔记 —— 04 为什么语言模型用文字接龙,图片模型不用像素接龙呢?
人工智能·笔记·深度学习·语言模型·自然语言处理
小龙报4 小时前
《彻底理解C语言指针全攻略(2)》
c语言·开发语言·c++·visualstudio·github·学习方法
少许极端5 小时前
算法奇妙屋(五)-链表
数据结构·算法·链表
木子.李3475 小时前
数据结构-算法C++(额外问题汇总)
数据结构·c++·算法
迎風吹頭髮6 小时前
UNIX下C语言编程与实践60-UNIX TCP 套接字关闭:close 与 shutdown 函数的区别与使用场景
c语言·网络·unix
程序员莫小特6 小时前
老题新解|计算2的N次方
开发语言·数据结构·算法·青少年编程·信息学奥赛一本通
memorycx6 小时前
听课笔记CSAPP
笔记
千忧散7 小时前
Unity Socket学习笔记 (三)TCP&UDP
笔记·学习·unity·c#
今天只学一颗糖7 小时前
Linux学习笔记--触摸屏驱动
笔记·学习