链表插入

#include <stdio.h>
#include <stdlib.h>

//我们需要先定义链表的结构体
typedef struct Link{
    int elem;
    struct Link * next;//这个是一个结构体型的指针
}link;

link *initLink(){
    link *p= (link*)malloc(sizeof(link));
    link *temp=p;
    for(int i=1;i<5;i++){
        link *a=(link*)malloc(sizeof(link));
        a->elem=i;
        a->next=NULL;
        temp->next=a;
        temp = temp->next;//这个地方不能是a->next;为什么?因为a->next指向的是NULL,temp=NULL,这是不行的,这相当于野指针。所以我们要用temp->next。
    }
    return p;
}

void display(link*p){
    link *temp = p;
    while (temp->next) {
        temp = temp->next;//这个地方要注意,需要手动的将指针下移一个位置
        printf("打印:%d\n",temp->elem);
    }
    printf("\n");
}

link *delElem(link *p, int elem,int add){
    link * temp =p;
    for(int i=1;i<add;i++){
        temp = temp->next;
    }
    
    link *c= (link*)malloc(sizeof(link));
    c->elem=elem;
    //这个地方为什嘛是temp->next呢?原先是1->2->3->4;我们要在第3个位置插入,
    c->next=temp->next;
    temp->next=c;
    return p;
}

int main(){
    link *p = initLink();
    link *p1 = delElem(p, 6, 3);
    display(p1);
    return 0;
}

这里主要讲插入。下面图示:
在这里插入图片描述
图示应该还算清楚。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值