Programa C para fazer uma segunda cópia de uma lista encadeada

Eu estava escrevendo um código em C para copiar o conteúdo de uma lista vinculada em outra lista. Eu quero saber se existe uma maneira mais eficiente de fazer isso.

Qual é melhor?

struct node *copy(struct node *start1)
{
struct node *start2=NULL,*previous=NULL;

while(start1!=NULL)
{
    struct node * temp = (struct node *) malloc (sizeof(struct node));
    temp->info=start1->info;
    temp->link=NULL;

    if(start2==NULL)
    {
        start2=temp;
        previous=temp;
    }
    else
    {
        previous->link=temp;
        previous=temp;          
    }
    start1=start1->link;
}
return start2;
}

OU

struct node *copy(struct node *start1)
{
    if(start1==NULL) return;
    struct node *temp=(struct node *) malloc(sizeof(struct node));
    temp->info=start1->info;
    temp->link=copy(start1->link);
    return temp;
}

questionAnswers(3)

yourAnswerToTheQuestion