C语言单链表插入问题 20

#include<stdio.h>#include<stdlib.h>#defineFALSE0#defineTRUE1typedefstructhappy{struct... #include<stdio.h>
#include<stdlib.h>
#define FALSE 0
#define TRUE 1
typedef struct happy{
struct happy *link;
int x;
}happy;
struct happy * k(struct happy *roob)//插入函数
{
struct happy *previous,*current=roob,*new_value;
previous=NULL;
while(current->x<value&¤t!=NULL)
{
previous=current;
current=current->link;
}

new_value=(happy *)malloc( sizeof(struct happy) );
if(new_value==NULL){printf("分配内存出错\n"),exit(0);}
new_value->x=value;
if(previous==NULL) //往第一位前面添加
{roob=new_value; }
if(current==NULL)//往最后添加-------------------问题所在。出错了
{perivious->link=new_value;new_value->link=NULL;}
else //在中间插入
{ previous->link=new_value;
new_value->link=current;}
return roob;
}
请问怎么在最后添加链表???
展开
 我来答
kwydwuf
2010-03-08 · TA获得超过7411个赞
知道大有可为答主
回答量:1527
采纳率:71%
帮助的人:2020万
展开全部
你的程序有几个问题:

while(current->x<value&¤t!=NULL)
应该改成
while(current != NULL && current->x<value)
先判断非空,再比较值

if(new_value==NULL){printf("分配内存出错\n"),exit(0);}
new_value->x=value;
改成
if(new_value==NULL){printf("分配内存出错\n"),exit(0);}
new_value->x=value;
new_value->link=NULL;
这样new_value是连表中第一个元素时,不会有问题

if(previous==NULL) //往第一位前面添加
{roob=new_value; }
改成
if(previous==NULL) //往第一位前面添加
{new_value->link = roob->link; roob=new_value }
否则你往第一位前面加时,就把后面的全丢掉了

if(current==NULL)//往最后添加
改成
else if (current==NULL)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式