C:将唯一值放在单个链表中

时间:2014-10-18 10:25:24

标签: c pointers struct

我试图在将值插入其中之前遍历链接列表。简单地说,我试图插入唯一值。请查看我的代码。 当我在GCC编译器中运行我的代码时,它给出了分段错误

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
struct link 
{
char name[14];
int data;
struct link *next;
}*start=NULL,*end=NULL,*tem=NULL;


void add(char nam[22])
{
struct link *temp;
temp=(struct link*)malloc(sizeof(struct link));
printf("Enter the data\n");
scanf("%d",&temp->data);
strcpy(temp->name,nam);
temp->next=NULL;
printf("\nadded\n");
if (start==NULL)
{
start=temp;
tem=start;
end=temp;
}
else
{
end->next=temp;
end=temp;
}


}

int traverse(char nam[22])
{
if(tem!=NULL){do
{
if(strcmp(tem->name,nam)==0)
{return 1;}
tem=tem->next;
}while(tem->next!=NULL);
}

return 0;
}

int main()
{
if(traverse("aaa")==0)
add("aaa");
else
printf("already present");

if(traverse("aaa")!=0)
printf("already present");
else
printf("not present ");//add("ashish");

if(traverse("bbb")!=0)
printf("already present");
else
printf("not present ");//add("bishnu");

return 0;
}

1 个答案:

答案 0 :(得分:0)

int traverse(char nam[22])
{
if(tem!=NULL){do
{
    if(strcmp(tem->name,nam)==0)
    {return 1;}
    tem=tem->next;
    }while(tem->next!=NULL);//this is error. You did not test tem==NULL after previos row
}

return 0;
}