单链表的插入操作

定义学生信息,包括学生性名(name)与年龄(age),定义函数:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct LinkList{
	char name[10];
	int age;
	struct LinkList *next;
}Student;

初始化数据表元素,创建InitList()函数

1、分配数据表空间

2、指定头节点的下一节点为NULL.

注意:如果不使用二重指针则无法对地址操作。初始化时必须要把地址传输过去。

/初始化
void InitList(Student* *sl){
	*sl=(Student*)malloc(sizeof(Student));  //分配空间
	(*sl)->next=NULL; //初始化
}

添加链表数据元素,创建InsertE()进行赋值操作。创建一个伪节点指向头节点和一个新节点(插入节点)并为新节点分配空间。循环遍历数据表使得伪节点指向最后一个节点并把新节点赋值给最后一个节点并赋值为空值。

//链表元素插入
void InsertE(Student* sl,char name[],int age){
	Student* temp = sl;
	Student* node_new=(Student*)malloc(sizeof(Student));//创建新节点,即插入节点并分配空间 
	while(temp->next!=NULL){
		temp=temp->next;//寻找尾节点的位置 
	}
	temp->next=node_new;//头节点的下一个节点指向插入节点 
	node_new->next=NULL;//插入节点的后一个节点为空 
    //赋值操作
	strcpy(node_new->name,name);
	node_new->age=age;
}

插入操作的主函数:

int main(){
	Student* sl; 
	InitList(&sl);
	InsertE(sl,"张三",18);
	InsertE(sl,"李四",19);
	InsertE(sl,"王五",18);
	InsertE(sl,"赵六",20);
}

 遍历函数:

//链表遍历输出
void Display(Student* sl){
	Student* dis = sl->next;
	printf("姓名:\t年龄:\n"); 
	while(dis!=NULL){
		printf("%s\t%d\n",dis->name,dis->age);
		dis=dis->next;
	}
	printf("\n");	
} 

 插入结果:

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值