复习C语言 链表的头插法和尾插法

在入门C语言时,大多数同学可能都会对C语言的指针头疼,尤其在大二接触数据结构设计中,然而,对于一个陌生的东西,你花在这个上面的时间越长,以后你对这块儿的知识点就会记忆的越深,今天就先复习一下数据结构中的第一课,链表的建立,这里我们首先要会使用c语言的结构体,在这里,我们默认定义的链表结构体如下:

typedef int ElemType;
typedef  struct Node {
    ElemType  data;
    struct Node *next;
}Node ;
typedef struct Node *LinkList;

对于链表的建立,我们常用的方法有两种,一种是头插法:代码如下

LinkList headInsert(LinkList L,int length){
    L = (Node *)malloc(sizeof(Node));
    L->next = NULL;
    int i = 0,temp;
    while(i<length){
        Node * p = (Node *)malloc(sizeof(Node));
        scanf("%d",&temp);
        p->data = temp;
        p->next = L->next;
        L->next = p;
        i++;
    }
    return L;
}

而另外一种方法则是尾插法:代码如下

LinkList tailInsert(LinkList L,int length){
    Node *q = (Node *)malloc(sizeof(Node));
    L = q;
    int temp,i=0;
    while(i<length){
        Node *p = (Node *)malloc(sizeof(Node));
        scanf("%d",&temp);
        p->data = temp;
        q->next = p;
        q = p;
        i++;
    }
    q->next = NULL;
    return L;

}

两种方法的使用是为了让我们更好的了解链表的结果和特性,虽然这两种方法看起来简单,但是对于初学者而言,需要多次反复练习,知识的积累需要沉淀,勤加练习吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值