data:image/s3,"s3://crabby-images/7878e/7878e2cd2aba86f1fa71cb9836c94e5dd0b7ba75" alt=""
data:image/s3,"s3://crabby-images/91827/9182753adfe9dcc3f0dd8d2e782bcb00d0478baa" alt=""
data:image/s3,"s3://crabby-images/ea330/ea3309fd19c7b0156618117dfed4ba4c744787d1" alt=""
data:image/s3,"s3://crabby-images/df8eb/df8eba5d998ac07ff3fcaf7127877a6b43f30375" alt=""
data:image/s3,"s3://crabby-images/88a93/88a93dba55f6b841ed78cc59613d5a9a917a7d70" alt=""
data:image/s3,"s3://crabby-images/38872/38872174b4e2bfaa95c20f3d773c7e5228afd986" alt=""
data:image/s3,"s3://crabby-images/35046/35046a7f1ab7c2df73961718eaf87c2240beca1e" alt=""
data:image/s3,"s3://crabby-images/f23aa/f23aa8f471122a4b7f3ae7336d76cf8a89c0ea5f" alt=""
data:image/s3,"s3://crabby-images/0fe81/0fe818f2debaa819379a2893c111ec66f3b38493" alt=""
data:image/s3,"s3://crabby-images/4ed3a/4ed3a69773fd7b246eac3accb13650c6f9222fc8" alt=""
data:image/s3,"s3://crabby-images/93ed8/93ed8eaf4ea5d343604fc5ddc2c2900bd76a329d" alt=""
data:image/s3,"s3://crabby-images/645a8/645a8a4eaca9ba285aa504e6c5c5380570761802" alt=""
data:image/s3,"s3://crabby-images/a0216/a0216723f4394d4fe6f8488299c599ad67d57456" alt=""
data:image/s3,"s3://crabby-images/3c658/3c6587d31a2a390264b9ba3daac1a0a7292640d0" alt=""
data:image/s3,"s3://crabby-images/02a2b/02a2b5806d2f536f148d8296842580a56af323bd" alt=""
data:image/s3,"s3://crabby-images/bbff8/bbff856eab36040309320859c93f4f2d5e61ba4e" alt=""
代码实现
#include<stdio.h>
#include<stdlib.h>
typedef struct LNode
{
int data;
struct LNode* next;
}LNode, * LinkList;
//创建头结点
LNode* InitList(LinkList L)
{
L = (LNode*)malloc(sizeof(LNode));
if (L == NULL)
{
printf("申请头结点失败\n");
return NULL;
}
L->data = 0;
L->next = NULL;
return L;
}
//判断链表为空
void Empty(LinkList L)
{
if (L->next == NULL)
{
printf("链表为空\n");
}
else
{
printf("链表不为空\n");
}
}
//按位序插入——指定节点的后插操作
//在第i个位置处插入元素e
int ListInsert(LinkList L, int i, int e)
{
if (i < 1)
{
printf("选择插入数据的位序错误\n");
return 1;
}
LNode* p; //指针p指向当前扫描到的节点
int j = 0; //j说明p当前指向的是第几个节点
p = L; //L指向头结点,头结点是第0个节点
while (p != NULL && j < i - 1) //循环指向需要插入的前一个位置
{
p = p->next;
j++;
}
if (p == NULL)
{
return 1;
}
LNode* s = (LNode*)malloc(sizeof(LNode)); //申请一个新节点
s->data = e; //给新节点赋值
s->next = p->next; //将新节点连接到p之后
p->next = s;
return 0;
}
//输出链表
int Print(LinkList L)
{
LNode* P = (LNode*)malloc(sizeof(LNode));
if (P == NULL)
{
printf("开辟空间失败\n");
return 1;
}
P = L;
while (P->next) //P->不为空
{
P = P->next; //将指针指向头结点的下一位
printf("%d ", P->data);
}
return 0;
}
//指定节点的前插操作
int InsertPriorNode(LinkList L, int e)
{
if (L == NULL)
{
return 1;
}
LNode* s = (LNode*)malloc(sizeof(LNode));
if (s == NULL)
{
return 1;
}
s->next = L->next;
L->next = s; //在要前插的节点后新增一个节点
s->data = L->data; //将要前插节点的数据赋值给新增节点
L->data = e; //将原来节点的数据域赋值为要前插的值
return 0;
}
//按位序删除
//删除第i个位置的节点,该节点的数据为e
int ListDelete(LinkList L, int i, int* e)
{
if (i < 1)
{
printf("需要删除的位序错误\n");
return 1;
}
LNode* p;
int j = 0;
p = L;
while (p != NULL && j < i - 1)
{
p = p->next;
j++;
}
if (p = NULL)
{
printf("创建指针p失败\n");
return 1;
}
if (p->next == NULL)
{
printf("要删除的节点不存在\n");
return 1;
}
LNode* q;
q = p->next; //令q指向被删除的节点
*e = q->data; //用e返回元素的值
p->next = q->next; //将q节点从链表中断开
free(q); //释放节点的存储空间
return 0;
}
int main()
{
LinkList L = (LNode*)malloc(sizeof(LNode));
InitList(L);
int i, e;
scanf("%d", &i);
for (int j = 1; j <= i; j++)
{
scanf("%d", &e);
ListInsert(L, j, e);
}
Print(L); return 0;
}