「Fundamental Of Data Structures in C」という本で与えられた関数に従ってこのコードを作成し、単純なリンクリストを実装するために次のコードを作成しましたが、本のコードのようにどこが間違っているのかわかりません。正しいはずです:
#include<stdio.h>
#include<stdlib.h>
typedef struct node *listpointer;
typedef struct {
int data;
listpointer link;
} node;
void print(listpointer first)
{
while (first) {
printf("%d\n",first->data);
first=first->link;
}
}
void addAtFront(listpointer *first,int n)
{
listpointer t=*first,temp;
temp=malloc(sizeof(node));
int i=1;
while (i <= n) {
t=t->link;
i++;
}
if(*first) {
temp->link=t->link;
temp->data=90;
t->link=temp;
}
else
{
*first=temp;
temp->link=NULL;
}
}
listpointer createList( )
{
listpointer first,second;
if(first=malloc(sizeof(node))) {
first->data=67;
if(second=malloc(sizeof(node))) {
second->data=65;
first->link=second;
second->link=NULL;
}
}
return first;
}
main( )
{
listpointer first=createList( );
addAtFront(&first,2);
print(first);
}