C语言-学生信息管理系统解析(链表)

  1. 基于链表的“学信息管理系统”

实验内容:编写并调试程序,实现学校各专业班级学生信息的管理。定义学生信息的链表结点类型,包括:学号、姓名、班级、专业、3门成绩。

实验要求:

    1. main函数:以菜单形式将各项功能提供给用户,根据用户的选择,调用相应的函数。
    2. 定义函数CreateList:按学号由小到大,建立有序的链表。逆序输入 n 个学生信息(调用n次input),学号大的先输入,建立带头结点的单链表。
    3. 定义函数Output:以指向某个学生结点的指针为参数,将学生信息格式化输出。
    4. 定义函数Save:将某个学生信息存入文件。
    5. 定义函数Fetch:从文件中随机读取某个学生的信息。
    6. 定义函数Search_num:查找指定学号的学生,返回指向该学生结点的指针。
    7. 定义函数InsertList:在函数中输入一个学生的信息,将该学生信息插入到链表中的相应位置,并保持此链表按学号的有序性。
    8. 定义函数Delete_num:从链表中删除指定学号的学生。
    9. 定义函数Search_major _subject_score:查找某个专业的、某门课程的成绩小于某个分数的学生,返回指向该学生结点的指针。
    10. 定义函数Delete_ major _subject:从链表中删除某个专业的、某门课程的成绩小于某个分数的学生。

题目如上

源代码:

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

typedef long long ll;

struct Student{
	char num[15];//学号
	char name[15];//姓名
	char major[10];//专业(computer,software,network)
	int classNo;//班级(1-2)
	int score[3];//3门课的成绩(0-2)
	ll numll;
	struct Student *next;
};
typedef struct Student STU;

STU *head=NULL;
STU *p=NULL,*pr=NULL;
int N;

STU* AppendNode(STU *head)//下一元素 
{
	STU *p=NULL,*pr=head;
	p=(STU*)malloc(sizeof(STU));
	if(head==NULL)
	{
		head=p;//第一次创建 
	}
	else//第二次及以后 
	{
		while(pr->next!=NULL) //pr给的头指针地址,每次添加都从头开始寻找 
		{
			pr=pr->next;//直到找到尾节点停止
		}
		pr->next=p; //给当前阶段尾节点以新创建的地址值 
	}
	p->next=NULL;//一定要给予next赋值为NULL,也就是某个阶段的尾节点一定是NULL值 
	return head;
}

void Input(STU *p)
{ 
	scanf("%s %s %s %d %d %d %d
1.基于数组的“学生信息管理系统” 实验内容: 编并调试程序,实现学校各专业班级学生信息的管理。定义学生信息的结构体类型,包括:学号、姓名、专业、班级、3门成绩。N定义为符号常量,定义N名学生信息的结构体数组。 实验要求: main函数:以菜单形式将各项功能提供给用户,根据用户的选择,调用相应的函数。 功能: (1)定义函数Input:功能是可以从键盘输入任意个学生信息。 (2)定义函数Save:将输入的学生信息全部或者选择性的存入指定文件(如:输入5个学生信息,选择其中前3或者2个存入文件,或者全部存入文件)。 (3)定义函数Output:将某个学生信息格式化输出(学生信息从文件中读取,并且提供可选择的学号)。 (4)定义函数Fetch:从文件中随机读取某个学生的信息。 (5)定义函数Del:删除指定学号学生信息,并保存到原文件中。 (6)定义函数:实现输出所有学生信息的功能(包括学生的平均分和总分)。 (7)定义函数Max:求所有学生某门课程的最高分,并将此学生的分数以及学生姓名输出(注意:当有多名相同最高分数时,可将所有学生姓名输出)。 (8)定义函数Sort_select:对某个专业的学生,按总平均成绩由低到高进行简单选择排序。 (9)定义函数Sort_buble:对某个专业中某个班级的学生,按总平均成绩由高到低进行起泡排序。 (10)定义函数Sort_insert:对某个专业中某个班级的学生,按某门课程成绩由低到高进行直接插入排序。 (11)定义函数Search:实现某专业中某班级的成绩综合查找(如智能专业1班,总分240分以上同学)。 (12) 定义函数printmenu: 打印菜单 退出 2.基于链表的“学生信息管理系统” 实验内容:编并调试程序,实现学校各专业班级学生信息的管理。定义学生信息的链表结点类型,包括:学号、姓名、班级、专业、3门成绩。 实验要求: (1)main函数:以菜单形式将各项功能提供给用户,根据用户的选择,调用相应的函数。 (2)定义函数CreateList:按学号由小到大,建立有序的链表。逆序输入 n 个学生信息(调用n次input),学号大的先输入,建立带头结点的单链表。 (3)定义函数Output:以指向某个学生结点的指针为参数,将学生信息格式化输出。 (4)定义函数Save:将某个学生信息存入文件。 (5)定义函数Fetch:从文件中随机读取某个学生的信息。 (6)定义函数Search_num:查找指定学号的学生,返回指向该学生结点的指针。 (7)定义函数InsertList:在函数中输入一个学生的信息,将该学生信息插入到链表中的相应位置,并保持此链表按学号的有序性。 (8)定义函数Delete_num:从链表中删除指定学号的学生。 (9)定义函数Search_major _subject_score:查找某个专业的、某门课程的成绩小于某个分数的学生,返回指向该学生结点的指针。 (10)定义函数Delete_ major _subject:从链表中删除某个专业的、某门课程的成绩小于某个分数的学生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值