单链表建立

第四周实践项目~单链表建立

#include <stdio.h>   
  1. #include <malloc.h>   
  2. typedef int ElemType;  
  3. typedef struct LNode          
  4. {  
  5.     ElemType data;  
  6.     struct LNode *next;       
  7. } LinkList;  
  8.   
  9. void CreateListF(LinkList *&L,ElemType a[],int n);  
  10. void CreateListR(LinkList *&L,ElemType a[],int n);  
  11. void DestroyList(LinkList *&L);   
  12. void DispList(LinkList *L)  ;  
  13.   
  14. int main()  
  15. {  
  16.     LinkList *L1, *L2;  
  17.     ElemType a[8]= {7, 9, 8, 2, 0, 4, 6, 3};  
  18.     CreateListF(L1, a, 8);  
  19.     printf("头插法建表结果:");  
  20.     DispList(L1);  
  21.     CreateListR(L2, a, 6);  
  22.     printf("尾插法建表结果:");  
  23.     DispList(L2);  
  24.     DestroyList(L1);  
  25.     DestroyList(L2);  
  26.     return 0;  
  27. }  
  28.   
  29.   
  30. void CreateListF(LinkList *&L,ElemType a[],int n)  
  31. {  
  32.     LinkList *s,*r;  
  33.     int i;  
  34.     L=(LinkList *)malloc(sizeof(LinkList));  
  35.     r=L;                                     
  36.     for (i=0;i<n;i++)                        
  37.     {  
  38.         s=(LinkList *)malloc(sizeof(LinkList));//创建新结点   
  39.         s->data=a[i];                      //创建数据节点*s   
  40.         r->next=s;                           
  41.         r=s;  
  42.     }  
  43.     r->next=NULL;                          //尾节点next域置于NULL   
  44. }  
  45. void CreateListR(LinkList *&L,ElemType a[],int n)//尾插法建立单链表   
  46. {  
  47.     LinkList *s,*r;  
  48.     int i;  
  49.     L=(LinkList *)malloc(sizeof(LinkList));//创建头结点   
  50.     L->next=NULL;  
  51.     r=L;                                   //r始终指向终端结点,开始时指向头结点   
  52.     for (i=0; i<n; i++)  
  53.     {  
  54.         s=(LinkList *)malloc(sizeof(LinkList));//创建新结点   
  55.         s->data=a[i];  
  56.         r->next=s;                          //将*s插入*r之后   
  57.         r=s;  
  58.     }  
  59.     r->next=NULL;                           //终端结点next域置为NULL   
  60. }  
  61.   
  62. void DestroyList(LinkList *&L)  //销毁单链表   
  63. {  
  64.     LinkList *p=L,*q=p->next;     
  65.     while (q!=NULL)              
  66.     {  
  67.         free(p);                //释放*p节点   
  68.         p=q;                      
  69.         q=p->next;              //再赋值   
  70.     }  
  71.     free(p);      
  72. }  
  73.   
  74. void DispList(LinkList *L)  //输出单链表   
  75. {  
  76.     LinkList *p=L->next;        //p指向开始节点   
  77.     while (p!=NULL)               
  78.     {  
  79.         printf("%d ",p->data);  
  80.         p=p->next;              //p移向下一个节点   
  81.     }  
  82.     printf("\n");  
  83. }  
#include <stdio.h>
#include <malloc.h>
typedef int ElemType;
typedef struct LNode        
{
    ElemType data;
    struct LNode *next;     
} LinkList;

void CreateListF(LinkList *&L,ElemType a[],int n);
void CreateListR(LinkList *&L,ElemType a[],int n);
void DestroyList(LinkList *&L); 
void DispList(LinkList *L)  ;

int main()
{
    LinkList *L1, *L2;
    ElemType a[8]= {7, 9, 8, 2, 0, 4, 6, 3};
    CreateListF(L1, a, 8);
    printf("头插法建表结果:");
    DispList(L1);
    CreateListR(L2, a, 6);
    printf("尾插法建表结果:");
    DispList(L2);
    DestroyList(L1);
    DestroyList(L2);
    return 0;
}


void CreateListF(LinkList *&L,ElemType a[],int n)
{
    LinkList *s,*r;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));
    r=L;                                   
    for (i=0;i<n;i++)                      
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];                      //创建数据节点*s
        r->next=s;                         
        r=s;
    }
    r->next=NULL;                          //尾节点next域置于NULL
}
void CreateListR(LinkList *&L,ElemType a[],int n)//尾插法建立单链表
{
    LinkList *s,*r;
    int i;
    L=(LinkList *)malloc(sizeof(LinkList));//创建头结点
    L->next=NULL;
    r=L;                                   //r始终指向终端结点,开始时指向头结点
    for (i=0; i<n; i++)
    {
        s=(LinkList *)malloc(sizeof(LinkList));//创建新结点
        s->data=a[i];
        r->next=s;                          //将*s插入*r之后
        r=s;
    }
    r->next=NULL;                           //终端结点next域置为NULL
}

void DestroyList(LinkList *&L)  //销毁单链表
{
    LinkList *p=L,*q=p->next;   
    while (q!=NULL)            
    {
        free(p);                //释放*p节点
        p=q;                    
        q=p->next;              //再赋值
    }
    free(p);    
}

void DispList(LinkList *L)  //输出单链表
{
    LinkList *p=L->next;        //p指向开始节点
    while (p!=NULL)             
    {
        printf("%d ",p->data);
        p=p->next;              //p移向下一个节点
    }
    printf("\n");
}

运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值