C语言创建单向链表之逆向建链

//逆向建链就相当于头插的过程,多想想头插的过程就明白了
#include"stdio.h"
#include"conio.h"
#include"malloc.h"
typedef struct ElemSN
{
       int data;
       struct ElemSN * next;
}ElemSN;
ElemSN * CreatLink(int  *a , int n);  //创建单向链表
void printLink(ElemSN * head);        //输出单向链表
void printLink(ElemSN * head)
{
       for(; head ; head=head->next)
            printf("%d  ", head->data);
}
ElemSN * CreatLink(int  *a ,int n)
{
       int i;
       ElemSN *head=NULL;
       ElemSN *p=NULL;
       for(i = n-1 ; i >= 0 ; i--)
       {
           head=(ElemSN *)malloc(sizeof(ElemSN));
           head->data=a[i];
           head->next=p;
           p=head;
      }                      
     return  head;
}
void main(void)
{
      ElemSN *head;
      int a[8]={1,2,3,4,5,6,7,8};
      head = CreatLink(a,8);
      printLink(head);
      getch();
}

你可能感兴趣的:(链表)