#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);
}
调试时不能显示链表的数据



											
	    

	