用链表实现学生管理系统

该代码实现了一个基于链表的数据结构,用于管理学生信息。包括创建链表、插入学生信息、按姓名和位置查找、删除指定位置学生、遍历显示所有学生信息、释放链表内存、对学生信息进行排序以及查找最高成绩的学生等功能。此外,还包含一个简单的用户交互菜单。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.头文件

#ifndef __LINKLIST_H__
#define __LINKLIST_H__

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

typedef struct 
{
	int id;
	char name[10];
	int score;
}student;


typedef student datatype;

typedef struct Node
{
	union
	{
		datatype data; //数据域
		int len;
	};
	struct Node *next; //指针域
}linkList;


//创建
linkList *list_create();

//判空
int list_empty(linkList *L);

//定义申请节点函数
linkList *node_buy(datatype e);

//尾插
int list_insert_tail(linkList *L,datatype e);

//按姓名查找返回第一个查找成功的位置
int list_search_value(linkList *L,char *str);

//按位置查找返回查找到的结点
linkList *find_node(linkList *L,int pos);

//任意删
int list_delete_pos(linkList *L,int pos);

//遍历
void list_show(linkList *L);

//释放
void list_free(linkList *L);

//排序
void *sort(linkList *L);

//查找最高成绩
linkList *max(linkList *L);

//菜单
void menu();


//循环输入学生信息
void input(linkList *L,int n);


//输入学生信息
student input1();

//循环输入学生信息
void input2(linkList *L,int n);

#endif

2.调用函数

#include "linklist.h"

//创建
linkList *list_create()
{
	linkList *L=(linkList*)malloc(sizeof(linkList));
	if(NULL==L)
	{
		//printf("创建失败\n");
		return NULL;
	}
	//初始化
	L->len=0;
	L->next=NULL;
	//printf("创建成功\n");
	return L;
}

//判空
int list_empty(linkList *L)
{

	//1表示空,0表示非空
	return NULL==L->next?1:0;
}

//定义申请节点函数
linkList *node_buy(datatype e)
{
	linkList *p=(linkList*)malloc(sizeof(linkList));
	if(NULL==p)
	{
		//printf("节点申请失败\n");
		return NULL;
	}
	//将数据存到节点中
	p->data=e;
	p->next=NULL;
	return p;
}

//尾插
int list_insert_tail(linkList *L,datatype e)
{
	//申请节点
	linkList *p=node_buy(e);
	//遍历指针指向最后一个节点
	linkList *s=L;
	while(s->next!=NULL)
	{
		s=s->next;
	}
	//尾插逻辑
	s->next=p;
	//表的变化
	L->len++;
	return 0;
}

//按姓名查找返回第一个查找成功的位置
int list_search_value(linkList *L,char *str)
{
	//查找逻辑
	linkList *q=L->next;
	for(int i=1;i<=L->len;i++)
	{
		if(strcmp(q->data.name,str)==0)
		{
			return i;
		}
		q=q->next;
	}
	return -1;
}

//按位置查找返回查找到的结点
linkList *find_node(linkList *L,int pos)
{
	//判断逻辑
	if(pos<0||pos>L->len)
	{
		//printf("查找失败\n");
		return NULL;
	}

	//查找结点
	linkList *q=L;
	for(int i=1;i<=pos;i++)
	{
		q=q->next;
	}
	return q;
}

//任意删
int list_delete_pos(linkList *L,int pos)
{
	//判断逻辑
	if(pos<1||pos>L->len)
	{
		//printf("删除失败\n");
		return -1;
	}

	//找到要删除位置的前驱
	linkList *q=find_node(L,pos-1);

	//删除逻辑
	linkList *p=q->next;
	q->next=p->next;
	free(p);
	p=NULL;

	//表的变化
	L->len--;

	//printf("删除成功\n");
	return 0;
}


//遍历
void list_show(linkList *L)
{
	//判断逻辑
	if(list_empty(L))
	{
		//printf("表空,遍历失败\n");
		return;
	}

	//遍历逻辑
	printf("学生信息:\n");
	linkList *q = L->next;
	while(q!=NULL)
	{
		printf("学号:%d\t姓名:%s\t成绩:%d\n",q->data.id,q->data.name,q->data.score);
		q=q->next;
	}
}

//释放
void list_free(linkList *L)
{
	if(NULL==L)
	{
		return;
	}
	//不断调用头删,将结点进行删除
	while(L->next!=NULL)
	{
		//头删
		linkList *p=L->next;
		L->next=p->next;
		free(p);
		p=NULL;

		//表的变化
		L->len--;
	}

	//将头结点释放
	free(L);
	L=NULL;
	printf("释放表成功\n");
	return;
}


//排序
void *sort(linkList *L)
{
	for(int i=1;i<L->len;i++)
	{
		for(int j=1;j<L->len-i+1;j++)
		{
			if(find_node(L,j)->data.score<find_node(L,j+1)->data.score)
			{
				student stu=find_node(L,j)->data;
				find_node(L,j)->data=find_node(L,j+1)->data;
				find_node(L,j+1)->data=stu;
			}
		}
	}
	
}

//查找最高成绩
linkList *max(linkList *L)
{
	if(list_empty(L))
	{
		return NULL;
	}
	linkList *p=L->next->next;
	linkList *q=L->next;
	int max=q->data.score;
	while(p!=NULL)
	{
		if(max<p->data.score)
		{
			max=p->data.score;
			q=p;
		}
		p=p->next;
	}
	return q;
}

//菜单
void menu()
{
	printf("************菜单*************\n");
	printf("*       1.增加学生          *\n");
	printf("*       2.删除学生          *\n");
	printf("*       3.查找学生          *\n");
	printf("*       4.查找最高分的学生  *\n");
	printf("*       5.排序              *\n");
	printf("*       6.输出学生信息      *\n");
	printf("*       7.退出              *\n");
	printf("*****************************\n");
}
//输入学生信息
student input1()
{
	int id,score;
	char name[10];
	printf("学号:");
	scanf("%d",&id);
	getchar();
	printf("姓名:");
	scanf("%s",name);
	printf("输入成绩:");
	scanf("%d",&score);
	student stu;
	stu.id=id;
	strcpy(stu.name,name);
	stu.score=score;
	return stu;
}



//循环输入学生信息
void input2(linkList *L,int n)
{
    for(int i=0;i<n;i++)
	{
		student stu=input1();
		list_insert_tail(L,stu);
	}
	printf("学生成绩输入成功\n");
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值