#include <stdio.h>
#include <malloc.h>
typedef struct LNode
{
int data;
struct LNode *next;
}Linklist;
Linklist *creatlist()
{
Linklist *s,*L;
int i,n,a[21];
L=(Linklist *)malloc(sizeof(Linklist));
printf("请输入数据的长度:\n");
scanf("%d",&n);
L->next=NULL;
for(i=0;i<=n-1;i++)
{printf("请输入数据:\n");
scanf("%d",&a[i]);
s=(Linklist *)malloc(sizeof(Linklist));
s->data=a[i];
s->next=L->next;
L->next=s;
}
return(L);
}
int Listinsert(Linklist *L,int i,int e)
{
int j=0;
Linklist *p=L,*s;
while(j<i-1&&p!=NULL)
{j++;
p=p->next;
}
if(p==NULL) return(0);
s=(Linklist *)malloc(sizeof(Linklist));
s->data=e;
s->next=p->next;
p->next=s;
return(1);
}
Listdelete(Linklist *L,int i)
{
int j=0;
Linklist *p=L,*q;
while(j<i-1&&p!=NULL)
{ j++;
p=p->next;
}
if(p==NULL)
return 0;
else
{ q=p->next;
if(q==NULL) return 0;
p->next=q->next;
free(q);
return 1;
}
}
void displist(Linklist *L)
{
Linklist *p=L->next;
while(p!=NULL)
{
printf("%d",p->data);
p=p->next;
}
printf("\n");
}
main()
{ Linklist *M;
int a,b;
M=creatlist();
displist(M);
printf("请插入要插入的位置和数据:");
scanf("%d %d",&a,&b);
Listinsert(M,a,b);
displist(M);
Listdelete(M,a);
displist(M);
}
调试时不能显示链表的数据