标题:大家看看啊,有关实现单链表的插入和删除
取消只看楼主
秋叶19861130
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2007-4-8
 问题点数:0 回复次数:0 
大家看看啊,有关实现单链表的插入和删除

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

搜索更多相关主题的帖子: 单链 删除 
2007-04-22 17:01



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-134025-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.123049 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved