概述
#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("打印:%dn",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;
}
这里主要讲插入。下面图示:
图示应该还算清楚。
最后
以上就是知性大米为你收集整理的链表插入的全部内容,希望文章能够帮你解决链表插入所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复