单链表的建立——带头结点和不带头结点
1.带头结点
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
typedef struct LNode { //定义单链表结点类型
int data; //每个节点存放一个数据元素
struct LNode* next; //指针指向下一个节点
}LNode,*LinkList;
bool InitList(LinkList& L) {
L = NULL;
return true;
}
LinkList List_HeadInsert(LinkList& L) {
LNode* s;
int x;
L = (LinkList)malloc(sizeof(LNode));//创建头结点
L->next = NULL;//初始化为空链表
scanf("%d", &x);//输入结点的值
while (x!=999) {//输入999表示结束
s = (LNode*)malloc(sizeof(LNode));//创建新结点
s->data = x;
s->next = L->next;
L->next = s;//将新节点插入表中,L为头指针
scanf("%d", &x);
}
return L;
}
int main() {
LinkList L;
//InitList(L);
//插入结点
List_HeadInsert(L);
//打印结点
L = L->next;
while (L != NULL) {
printf("%d\n", L->data);
L = L->next;
}
return 0;
}
2.不带头结点
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
typedef struct LNode { //定义单链表结点类型
int 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;
}
//在第i个位置插入元素e(带头结点)
bool ListInsert(LinkList& L, int i, int e) {
if (i == 1) {
LNode* s = (LNode*)malloc(sizeof(LNode));
s->data = e;
s->next = L;
L = s; //头指针指向新节点
return true;
}
LNode* p; //指针p指向当前扫描到的结点
int j = 1; //当前p指向的是第几个结点
p = L; //第1个结点
while (p!=NULL && j < i - 1) { //循环找到第i-1个结点
p = p->next;
j++;
}
if (p == NULL) {//i值不合法
return false;
}
LNode* s = (LNode*)malloc(sizeof(LNode));//申请一个结点
s->data = e;
s->next = p->next;
p->next = s;//将结点s连接到p之后
return true;//插入成功
}
void test(){
LinkList L;
InitList(L);
//插入数据
ListInsert(L, 1, 5);
ListInsert(L, 2, 6);
ListInsert(L, 3, 9);
//打印数据
while (L->next!=NULL) {
printf("%d\n", L->data);
L = L->next;
}
}
int main() {
test();
return 0;
}