单链表的定义(实现)
比较顺序表和单链表的物理存储结构就能够清楚地发现二者的区别
用代码定义一个单链表
typedef struct LNode{ElemType data; //每个结点存放一个数据元素struct LNode* next; //指针指向下一个结点
}LNode, *LinkList;//要表示一个单链表时,只需声明一个头指针L,指向单链表的第一个结点
LNode* L; //➡️ 强调这是一个结点
LinkList L; //➡️ 强调这是一个单链表
//以上两种声明方式都可以,建议使用第二种,代码可读性更强
单链表的初始化
不带头节点的单链表
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;
}
带头节点的单链表
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;
}
总结
不带头结点,写代码更麻烦
对第一个数据结点和后续数据结点的处理需要用不同的代码逻辑
对空表和非空表的处理需要用不同的代码逻辑
带头结点,写代码更方便
本文主要参考《王道计算机考研 数据结构》课程视频