C语言搭建项目-学生管理系统(非链表)

目录

搭建offer.h文件

搭建offer.c中的main函数

密码登入系统

搭建my_oferr.c中的接口函数 

使用帮助菜单接口函数

增加学生信息接口函数 

查询学生信息接口函数

删除学生信息接口函数 

保存学生信息接口 

打开文件fopen

关闭文件fclose

 判断是否保存文件fwrite

退出执行文件exit

显示学生信息接口函数

 修改学生信息接口函数

 学生排名信息接口函数

--------------------------------------

---------------- 

每次归程,都是为了更好出发;

每次停歇,都是为了积攒力量 。

最近大家C语言是不是都进入了实训阶段呢?

还在为写不出代码而苦恼吗?

接下来我将带领大家一起完成!

C语言的一个简单项目-学生管理系统!

主要运用了数组和指针函数

关于链表的搭建后续会更新

题目:学生管理系统
学生数据由学号、姓名、性别、年龄、三门课(C语言、高数、大物)的成绩构成

 实现功能包括:
(1)密码登入
(2)使用提示
(3)信息录入
(4)查询信息
(5)删除信息
(6)保存信息
(7)显示信息

(8)修改信息

(9)成绩排名

对于这种代码量超百位数的,大家最好养成分模块写代码的习惯:

我创建了一个.h文件和两个.c 文件,.h一般放头文件和结构体类型.c文件一个设置主函数main一个完善相应的函数接口。这样分工明确,不会混乱,可以提高敲代码的效率哦~

首先明白我们要实现的项目功能:密码登入系统、使用帮助菜单、增加学生信息、查询学生信息、删除学生信息、保存当前信息、显示当前信息、修改学生信息、学生成绩排名


搭建offer.h文件

因为学生有以下几个基本信息:姓名、年龄、学号、性别,依次由name、age、id和sex来表示,所以可以通过结构体实现,struct语句定义存储不同类型的数据项,定义一个结构体数组Stu,用于存储每个学生的信息

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
void TiShi();      //提示功能
void StuXinXi();   //增加信息
void ChaZhao();    //查找信息
void ShanGai();    //删改信息
void BaoCun();     //保存信息
void XianShi();    //显示信息
void XiuGai();     //修改信息
void PaiMing();    //学生排名
#define N 20
#define Number sizeof(struct Student)//求结构体的大小    
//创建结构体包含学生信息
struct Student
{
	char Stuid[N];     //学号
	char Stuname[N];   //名字
	int Stuage;        //年龄
	char Stusex[N];    //性别
	double score[3];   //成绩
}Stu[Number];
//枚举体美化选项
enum menu2
{
	Quit = 0,
	Resume = 1
};
enum ChaZhao
{
	CaoZuo1 = 1,
	CaoZuo2 = 2,
	CaoZuo3 = 3
};

1.这里最好定义一个宏#define不然以后修改将会很麻烦

2.枚举体美化选项在我之前的博客讲过,提高代码的可读性

3.剩下的就是头文件的引入和函数的声明以及结构体的创建

搭建offer.c中的main函数

 要使用我们在offer.h中设置的头文件要在offer.c中加上#include"offer.h"

#include"offer.h"

 整体的框架如下:

#include"offer.h"
int sum = 1;
int main()
{
	int i = 0;
	int input = 0, count = 0;
	char mima[20] = "123";//登入的密码
	char shuru[20];
	system("color F4");
	printf("\t\t\t     **************************************\n");
	printf("\t\t\t     |       *欢迎使用学生管理系统*       |\n");
	printf("\t\t\t     |           *管理员: 小唐*           |\n");
	printf("\t\t\t      ------------------------------------\n");
	printf("请输入管理员密码:\n");
	while ((count = _getch()) != '\r')   
	{
		if (count == '\b')
		{
			i--;
			printf("\b \b");
		}
		else
		{
			shuru[i++] = count;
			printf("*");
		}
	}
	shuru[i++] = '\0';    //getch赋值的是单个字符,所以为了比较两个字符串的大小要给shuru数组后面添加'\0'
	if (strcmp(mima, shuru) == 0)
	{
		printf("\n密码正确,您已进入系统!\n");
	}
	else
	{
		printf("\n密码错误,请重新输入!\n");
		return 0;
	}
    system("pause");
	system("cls");
	do
	{
		menu2();
		printf("请选择继续还是结束操作:\n");
		scanf("%d", &sum);
		switch (sum)
		{
		case Quit:
			system("cls");//清除屏幕
			printf("您已退出学生管理系统!\n");
			break;
		case Resume:
			menu1();
			void(*p[9])() = { NULL,TiShi,StuXinXi,ChaZhao,ShanGai,BaoCun,XianShi,XiuGai,PaiMing };//指针数组函数
			printf("请输入你要进行的操作\n");
			scanf("%d", &input);
			system("cls");
			(*p[input])();
			break;
		default:
			printf("输入错误,重新输入!\n");
			break;
		}
	} while (sum);
	return 0;
}

接下来我将带领大家解读以上代码

密码登入系统

在进入学生管理系统之前,我设置了一个小型的系统密码登入界面来判断是进入还是退出

	int count = 0;
	char mima[20] = "123";//登入的密码
	char shuru[20];
	system("color F4");
	printf("\t\t\t     **************************************\n");
	printf("\t\t\t     |       *欢迎使用学生管理系统*       |\n");
	printf("\t\t\t     |           *管理员: 小唐*           |\n");
	printf("\t\t\t      ------------------------------------\n");
	printf("请输入管理员密码:\n");
	while ((count = _getch()) != '\r')   
	{
		if (count == '\b')
		{
			i--;
			printf("\b \b");
		}
		else
		{
			shuru[i++] = count;
			printf("*");
		}
	}
	shuru[i++] = '\0';    //getch赋值的是单个字符,所以为了比较两个字符串的大小要给shuru数组后面添加'\0'
	if (strcmp(mima, shuru) == 0)
	{
		printf("\n密码正确,您已进入系统!\n");
	}
	else
	{
		printf("\n密码错误,请重新输入!\n");
		return 0;
	}

1.我们这里利用了while去进行getch输入getch输入单个字符是不会显示信息的,但我们按下回车键输入结束,循环停止

2.' \r '就是回车键的意思,而' \b '就是删除键的意思

3.每循环一次就输入一个字符count赋值给数组shuru,并打印" * "

4.getch赋值的是单个字符,所以为了比较两个字符串的大小要给shuru数组后面添加' \0 '

5.strcmp是比较两个字符串的大小,详细可以看我之前的博客

以上就是我们密码登入系统的全部内容

接下来我将讲解接下来的代码实现

 menu2()的作用就是选择继续操作还是退出系统

void menu2()
{
	system("color F4");
	printf("\t\t\t*********************\n");
	printf("\t\t\t*********************\n");
	printf("\t\t\t-------1.Resume------\n");
	printf("\t\t\t-------0.Quit--------\n");
	printf("\t\t\t*********************\n");
}

1.system("cls")-清屏函数,会将显示过的内容清空,被#include<stdlib.h>包含

2.system("color F4");是改变背景颜色的函数,被#include<stdlib>包含

3.我们用枚举类型美化选项Quit就是0,Resume就是1

4.我们采用了指针数组函数可以直接调用接口函数,因为没有返回值函数类型就是void,这样减少了重复代码的编写,如果大家不适应也可以用switch


搭建my_oferr.c中的接口函数 

首先定义我们my_oferr.c中的全局变量

#include"offer.h"
int m = 0;              //记录录入学生的人数

由于是显示一个管理系统

所以我们设计一个主菜单

通过定义一个函数menu1()来实现这个功能:

void menu1()
{
	printf("\n");
	system("color F4");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t*---------------------------------------------------*\n");
	printf("\t\t\t*                   学生管理系统                    *\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t********************系统功能菜单*********************\n");
	printf("\t\t\t----------------------     --------------------------\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    1、使用帮助菜单   *     2、增加学生信息      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    3、查询学生信息   *     4、删除学生信息      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    5、保存当前信息   *     6、显示当前信息      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    7、修改学生信息   *     8、学生成绩排名      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t----------------------     --------------------------\n");
}

这个大家可以自己随喜好设置~ 


 使用帮助菜单接口函数

void TiShi()
{
	printf("欢迎来到学生管理系统:\n");
	printf("在这个管理系统中,教师和学生都不需要去了解自己的信息,只需通过网络就能实现自己的信息管理。\n");
	printf("教师可以轻松便捷地掌握学生相关情况、姓名、学号以及考试成绩等基本信息。\n");
	printf("它还提供一个搜索功能和设置权限,可以将学生的信息进行搜索,\n也可根据关键字或其他方式对其进行定位,并且还能显示出该人的相关基本资料。\n");
	printf("如果由技术上的缺陷还请联系项目负责人:\n17817473648\n");
	system("pause");
	system("cls");
}

 system("pause")是暂停函数,按任意键重新启动,被#include<stdlib.h>包含

本函数接口主要起到提示作用,小伙伴们可以自行添加自己的管理需求 


 增加学生信息接口函数 

void StuXinXi()
{
	int i = m,flag,n = 0;
	printf("请输入你要添加的学生人数:\n");
	scanf("%d", &n);
	printf("--------------------------*学生信息录入系统*--------------------------------\n");
	if (n > 0)
	{
		do {
			flag = 1;
			while (flag)
			{
				flag = 0;
				printf("请输入第%d位学生的学号:\n", i + 1);
				scanf("%s", Stu[i].Stuid);
				for (int j = 0; j < i; j++)
				{
					if (strcmp(Stu[i].Stuid, Stu[j].Stuid) == 0)
						//判断是否重复
					{
						printf("该学生已经录入,请重新选择!\n");
						flag = 1;
						break;
					}
				}
			}
			printf("请输入第%d学生的姓名:\n", i + 1);
			scanf("%s", Stu[i].Stuname);
			printf("请输入第%d学生的年龄:\n", i + 1);
			scanf("%d", &Stu[i].Stuage);
			printf("请输入第%d学生的性别:\n", i + 1);
			scanf("%s", &Stu[i].Stusex);
			printf("请输入第%d学生的C语言成绩:\n", i + 1);
			scanf("%lf", &Stu[i].score[0]);
			printf("请输入第%d学生的高数成绩:\n", i + 1);
			scanf("%lf", &Stu[i].score[1]);
			printf("请输入第%d学生的大物成绩:\n", i + 1);
			scanf("%lf", &Stu[i].score[2]);
			i++;
		} while (i < n + m);
		m += n;
	if (flag == 0)
	{
		printf("添加完成!请进行下一步操作:\n");
	}
		system("pause");
		system("cls");
	}
}

1.flag用来判断最后输出的提示语句,提示录入成功与否

2.然后就是whie循环给结构体成员赋初值

3.在将人数累加给全局变量m就好了


查询学生信息接口函数

void ChaZhao()
{
	int flag, input;
	char Stu1[Number];
	printf("\t\t\t----------*学生信息查找系统*----------\n");
	printf("\t\t\t**************************************\n");
	printf("\t\t\t******1.请输入你要查找的学生名字******\n");
	printf("\t\t\t******2.请输入你要查找的学生学号******\n");
	printf("\t\t\t******------3.退出本次操作------******\n");
	printf("\t\t\t**************************************\n");
	while (1)
	{
		flag = 0;
		printf("请输入你要进行的查询操作:\n");
		scanf("%d", &input);
		switch (input)
		{
		case CaoZuo1:
			printf("请输入你要查找的学生名字:\n");
			scanf("%s", Stu1);
			for (int i = 0; i < m; i++)
			{
				if (strcmp(Stu[i].Stuname, Stu1) == 0)
				{
					flag = 1;
					printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
					printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
				}
			}break;
		case CaoZuo2:
			printf("请输入你要查找的学生学号:\n");
			scanf("%s", Stu1);
			for (int i = 0; i < m; i++)
			{
				if (strcmp(Stu[i].Stuid, Stu1) == 0)
				{
					flag = 1;
					printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
					printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
				}
			}break;
		case CaoZuo3:
			return;
		default:
			printf("输入错误,重新选择!\n");
		}
		if (flag == 0)
		{
			printf("该学生没有录入系统,请重新查找!\n");
		}
	}
	system("pause");
}


删除学生信息接口函数 

void ShanGai()
{
	int flag = 0;
	char arr[Number];  //定义一个数组
	printf("----------------------------------*学生名单*----------------------------------------------------------\n");
	printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
	for (int i = 0; i < m; i++)
	{
		printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
	}
	printf("请输入你要删除学生的学号:\n");
	scanf("%s", arr);
	for (int i = 0; i < m; i++)
	{
		if (strcmp(Stu[i].Stuid, arr) == 0) //查找对应的学号
		{
			flag = 1;
			for (int j = i; j < m - 1; j++) //m-1防止越界访问
			{
				Stu[j] = Stu[j + 1];      //整个结构体后一个覆盖前一个
			}
		}
	}
	if (flag == 0)
	{
		printf("无法查找该学生信息!\n");
	}
	else
	{
		printf("删除成功,请查询系统!\n");
		m--;           //删除成功总人数减一
		printf("----------------------------------*学生名单*----------------------------------------------------------\n");
		printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
		for (int i = 0; i < m; i++)
		{
			printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
		}
	}
	system("pause");
}

保存学生信息接口 

这里穿插一下文件的保存的函数内容: 

打开文件fopen

可以使用 fopen( ) 函数来创建一个新的文件或者打开一个已有的文件,这个调用会初始化类型 FILE 的一个对象,类型 FILE 包含了所有用来控制流的必要的信息。下面是这个函数调用的原型:

FILE *fopen( const char *filename, const char *mode );

在这里,filename 是字符串,用来命名文件,访问模式 mode 的值可以是下列值中的一个:

关闭文件fclose

为了关闭文件,请使用 fclose( ) 函数。函数的原型如下:

 int fclose( FILE *fp );

如果成功关闭文件,fclose( ) 函数返回零,如果关闭文件时发生错误,函数返回 EOF。这个函数实际上,会清空缓冲区中的数据,关闭文件,并释放用于该文件的所有内存。EOF 是一个定义在头文件 #include<stdio.h> 中的常量。

 判断是否保存文件fwrite

fwrite(file,string,length)
file必需。规定要写入的打开文件。
string必需。规定要写入打开文件的字符串。
length可选。规定要写入的最大字节数。

fwrite() 函数将内容写入一个打开的文件中,并以二进制的形式进行输出

函数会在到达指定长度或读到文件末尾(EOF)时(以先到者为准),停止运行

如果函数成功执行,则返回写入的字节数。如果失败,则返回 FALSE

退出执行文件exit

void exit(int status) 

立即终止调用进程。任何属于该进程的打开的文件描述符都会被关闭,该进程的子进程由进程 1 继承,初始化,且会向父进程发送一个 SIGCHLD 信号。 

void BaoCun()
{
	FILE* fp;              //文件指针
	char filename[Number];
	printf("------------------------------\n");
	printf("---*请输入你要保存的文件名*---\n");
	printf("------------------------------\n");
	scanf("%s", filename);
	if (fp = fopen("filename.txt", "a")== NULL)//fopen以.txt的形式打开文件函数
	{
		printf("打开文件失败!\n");
		exit(0);
	}
	for (int i = 0; i < m; i++)
	{
		if (fwrite(&Stu[i], sizeof(struct Student), 1, fp) != 1)
		{
			printf("保存失败!\n");
		}
		else
		{
			printf("保存成功!\n");    //返回字节数,则成功保存
		}
	}
	fclose(fp);   //关闭文件
    fp = NULL;    //防止fp变为野指针
	system("pause");
}

我们保存之后在这里查看保存过的文件: 

显示学生信息接口函数

void XianShi()
{
	if (m == 0)
	{
		printf("您好!现在还暂未录入学生信息,请稍后重试");
	}
	else 
	{
		printf("现在有%d名学生:\n", m);
		printf("-------------------------------------*成绩显示*----------------------------------------------\n");
		printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
		for (int i = 0; i < m; i++)
		{
			printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
		}
	}
	system("pause");
}

 

 修改学生信息接口函数

void XiuGai()
{
	int input = 0;
	int  flag;
	char id[Number], name[Number], sex[Number];
	int age;
	double score;
	printf("请输入要修改的学生学号:\n");
	scanf("%s", &id);
	while (1)
	{
		flag = 0;
		for (int i = 0; i < m; i++)
		{
			if (strcmp(id, Stu[i].Stuid) == 0)
			{
				flag = 1;
				printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
				printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
				printf("**************************************************\n");
				printf("----1.修改学生性别             2.修改学生姓名-----\n");
				printf("----3.修改学生年龄             4.修改C语言成绩----\n");
				printf("----5.修改高数成绩             6.修改大物成绩-----\n");
				printf("********************7.退出本菜单******************\n");
				printf("请输入你要修改的选项:\n");
				scanf("%d", &input);
				switch (input)
				{
				case 1:
					printf("请输入要修改的性别:\n");
					scanf("%s", sex);
					strcpy(Stu[i].Stusex, sex);
					break;
				case 2:
					printf("请输入要修改的姓名:\n");
					scanf("%s",name);
					strcpy(Stu[i].Stuname, name);
					break;
				case 3:
					printf("请输入要修改的年龄:\n");
					scanf("%d", &age);
					Stu[i].Stuage = age;
					break;
				case 4:
					printf("请输入要修改的C语言成绩:\n");
					scanf("%lf", &score);
					Stu[i].score[0] = score;
					break;
				case 5:
					printf("请输入要修改的高数成绩:\n");
					scanf("%lf", &score);
					Stu[i].score[1] = score;
					break;
				case 6:
					printf("请输入要修改的大物成绩:\n");
					scanf("%lf", &score);
					Stu[i].score[2] = score;
					break;
				case 7:
					return;
				default:
					printf("选择错误,请重新选择!\n");
					break;
				}
			}
			if (1 <= input && input <= 6)
			{
				printf("恭喜你修改成功!\n");
				break;
			}
			
			if (flag == 0)
			{
				printf("没有找到该学生信息,请重新输入学生学号:\n");
				gets(name);
			}
		}
	}
	system("pause");
}

char* strcpy(char * destination, const char * source ); 

strcpy:拷贝函数,将括号右边的值拷贝到左边,详细可看我之前的博客

 学生排名信息接口函数

int PaiXu(const void* e1, const void* e2)
{
	return  ((struct Student*)e2)->score[0] - ((struct Student*)e1)->score[0];
}
int PaiXu1(const void* e1, const void* e2)
{
	return  ((struct Student*)e2)->score[0] - ((struct Student*)e1)->score[0];
}
int PaiXu2(const void* e1, const void* e2)
{
	return  ((struct Student*)e2)->score[2] - ((struct Student*)e1)->score[2];
}
void PaiMing()
{
	int input = 0;
	while (1)
	{
		printf("\t\t**************************************************\n");
		printf("\t\t---------------------***光荣榜***-----------------\n");
		printf("\t\t**************************************************\n");
		printf("\t\t********1.C语言-------------------2.高数**********\n");
		printf("\t\t********3.大物--------------------4.退出系统******\n");
		printf("\t\t**************************************************\n");
		printf("请输入你要查询的排名:\n");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			printf("\t学号:\t\t名字:\tC语言成绩:\n");
			int rs = sizeof(Stu) / sizeof(Stu[0]);
			qsort(Stu, rs, sizeof(Stu[0]), PaiXu);//排序
			for (int i = 0; i < m; i++)
			{
				printf("第%d名\t%s\t%s\t%.2lf", i+1, Stu[i].Stuid, Stu[i].Stuname, Stu[i].score[0]);
				printf("\n");
			}
			break;
		case 2:
			printf("\t学号:\t\t名字:\t高数成绩:\n");
			int rs1 = sizeof(Stu) / sizeof(Stu[0]);
			qsort(Stu, rs1, sizeof(Stu[0]), PaiXu1);
			for (int i = 0; i < m; i++)
			{
				printf("第%d名\t%s\t%s\t%.2lf", i+1, Stu[i].Stuid, Stu[i].Stuname, Stu[i].score[0]);
				printf("\n");
			}
			break;
		case 3:
			printf("\t学号:\t\t名字:\t大物成绩:\n");
			int rs2 = sizeof(Stu) / sizeof(Stu[0]);
			qsort(Stu, rs, sizeof(Stu[0]), PaiXu2);
			for (int i = 0; i < m; i++)
			{
				printf("第%d名\t%s\t%s\t%.2lf", i+1, Stu[i].Stuid, Stu[i].Stuname, Stu[i].score[0]);
				printf("\n");
			}
			break;
		case 4:
			return;
		default:
			printf("选择错误,重新选择!\n");
			break;
		}
	}
}

我们采用qsort排序法:

void qsort (void* base, size_t num, size_t size, int (*compar)(const void*,const void*));

base首元素地址-数组名

num元素个数

size数据类型的大小

int (*compar)(const void*,const void*))比较大小的函数指针 

以下是整个代码的实现:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define N 20      
#define Number sizeof(struct Student)
struct Student
{
	char Stuid[N];    
	char Stuname[N];  
	int Stuage;        
	char Stusex[N];       
	double score[3];  
}Stu[Number];
enum menu2
{
	Quit = 0,
	Resume = 1
};
enum ChaZhao
{
	CaoZuo1 = 1,
	CaoZuo2 = 2,
	CaoZuo3 = 3
};

int m = 0;
void menu1()
{
	printf("\n");
	system("color F4");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t*---------------------------------------------------*\n");
	printf("\t\t\t*                   学生管理系统                    *\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t********************系统功能菜单*********************\n");
	printf("\t\t\t----------------------     --------------------------\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    1、使用帮助菜单   *     2、增加学生信息      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    3、查询学生信息   *     4、删除学生信息      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    5、保存当前信息   *     6、显示当前信息      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t**    7、修改学生信息   *     8、学生成绩排名      **\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t*****************************************************\n");
	printf("\t\t\t----------------------     --------------------------\n");
}
void menu2()
{
	system("color F4");
	printf("*********************\n");
	printf("*********************\n");
	printf("-------1.Resume------\n");
	printf("-------0.Quit--------\n");
	printf("*********************\n");
}
void TiShi()
{
	printf("欢迎来到学生管理系统:\n");
	printf("在这个管理系统中,教师和学生都不需要去了解自己的信息,只需通过网络就能实现自己的信息管理。\n");
	printf("教师可以轻松便捷地掌握学生相关情况、姓名、学号以及考试成绩等基本信息。\n");
	printf("它还提供一个搜索功能和设置权限,可以将学生的信息进行搜索,\n也可根据关键字或其他方式对其进行定位,并且还能显示出该人的相关基本资料。\n");
	printf("如果由技术上的缺陷还请联系项目负责人:\n唐工:2172227341@qq.com\n");
	system("pause");
	system("cls");
}
void StuXinXi()
{
	int i = m,flag,n = 0;
	printf("请输入你要添加的学生人数:\n");
	scanf("%d", &n);
	printf("--------------------------*学生信息录入系统*--------------------------------\n");
	if (n > 0)
	{
		do {
			flag = 1;
			while (flag)
			{
				flag = 0;
				printf("请输入第%d位学生的学号:\n", i + 1);
				scanf("%s", Stu[i].Stuid);
				for (int j = 0; j < i; j++)
				{
					if (strcmp(Stu[i].Stuid, Stu[j].Stuid) == 0)
					{
						printf("该学生已经录入,请重新选择!\n");
						flag = 1;
						break;
					}
				}
			}
			printf("请输入第%d学生的姓名:\n", i + 1);
			scanf("%s", Stu[i].Stuname);
			printf("请输入第%d学生的年龄:\n", i + 1);
			scanf("%d", &Stu[i].Stuage);
			printf("请输入第%d学生的性别:\n", i + 1);
			scanf("%s", &Stu[i].Stusex);
			printf("请输入第%d学生的C语言成绩:\n", i + 1);
			scanf("%lf", &Stu[i].score[0]);
			printf("请输入第%d学生的高数成绩:\n", i + 1);
			scanf("%lf", &Stu[i].score[1]);
			printf("请输入第%d学生的大物成绩:\n", i + 1);
			scanf("%lf", &Stu[i].score[2]);
			i++;
		} while (i < n + m);
		m += n;
		if (flag == 0)
		{
			printf("添加完成!请进行下一步操作:\n");
		}
		system("pause");
		system("cls");
	}
}
void ChaZhao()
{
		int flag, input;
		char Stu1[Number];
		printf("\t\t\t----------*学生信息查找系统*----------\n");
		printf("\t\t\t**************************************\n");
		printf("\t\t\t******1.请输入你要查找的学生名字******\n");
		printf("\t\t\t******2.请输入你要查找的学生学号******\n");
		printf("\t\t\t******------3.退出本次操作------******\n");
		printf("\t\t\t**************************************\n");
		while (1)
		{
			flag = 0;
			printf("请输入你要进行的查询操作:\n");
			scanf("%d", &input);
			switch (input)
			{
			case CaoZuo1:
				printf("请输入你要查找的学生名字:\n");
				scanf("%s", Stu1);
				for (int i = 0; i < m; i++)
				{
					if (strcmp(Stu[i].Stuname, Stu1) == 0)
					{
						flag = 1;
						printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
						printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
					}
				}break;
			case CaoZuo2:
				printf("请输入你要查找的学生学号:\n");
				scanf("%s", Stu1);
				for (int i = 0; i < m; i++)
				{
					if (strcmp(Stu[i].Stuid, Stu1) == 0)
					{
						flag = 1;
						printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
						printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
					}
				}break;
			case CaoZuo3:
				return;
			default:
				printf("输入错误,重新选择!\n");
			}
			if (flag == 0)
			{
				printf("该学生没有录入系统,请重新查找!\n");
			}
		}
		system("pause");
	}   
void ShanGai()
{
	int flag = 0;
	char arr[Number];
	printf("----------------------------------*学生名单*----------------------------------------------------------\n");
	printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
	for (int i = 0; i < m; i++)
	{
		printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
	}
	printf("请输入你要删除学生的学号:\n");
	scanf("%s", arr);
	for (int i = 0; i < m; i++)
	{
		if (strcmp(Stu[i].Stuid, arr) == 0) 
		{
			flag = 1;
			for (int j = i; j < m - 1; j++) 
			{
				Stu[j] = Stu[j + 1];      
			}
		}
	}
	if (flag == 0)
	{
		printf("无法查找该学生信息!\n");
	}
	else
	{
		printf("删除成功,请查询系统!\n");
		m--;          
		printf("----------------------------------*学生名单*----------------------------------------------------------\n");
		printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
		for (int i = 0; i < m; i++)
		{
			printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
		}
	}
	system("pause");
}
void BaoCun()
{
	FILE* fp;              
	char filename[Number];
	printf("------------------------------\n");
	printf("---*请输入你要保存的文件名*---\n");
	printf("------------------------------\n");
	scanf("%s", filename);
	if (fp = fopen("filename.txt", "a")== NULL)
	{
		printf("打开文件失败!\n");
		exit(0);
	}
	for (int i = 0; i < m; i++)
	{
		if (fwrite(&Stu[i], sizeof(struct Student), 1, fp) != 1)
		{
			printf("保存失败!\n");
		}
		else
		{
			printf("保存成功!\n");
		}
	}
	fclose(fp);
    fp = NULL;  
	system("pause");
}
void XianShi()
{
	if (m == 0)
	{
		printf("您好!现在还暂未录入学生信息,请稍后重试");
	}
	else 
	{
		printf("现在有%d名学生:\n", m);
		printf("-------------------------------------*成绩显示*----------------------------------------------\n");
		printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
		for (int i = 0; i < m; i++)
		{
			printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
		}
	}
	system("pause");
}
void XiuGai()
{
	int input = 0;
	int  flag;
	char id[Number], name[Number], sex[Number];
	int age;
	double score;
	printf("请输入要修改的学生学号:\n");
	scanf("%s", &id);
	while (1)
	{
		flag = 0;
		for (int i = 0; i < m; i++)
		{
			if (strcmp(id, Stu[i].Stuid) == 0)
			{
				flag = 1;
				printf("学号:\t\t名字:\t年龄:\t性别:\tC语言成绩:\t高数成绩:\t大物成绩:\n");
				printf("%s\t%s\t%d\t%s\t%.2lf\t\t%.2lf\t\t%.2lf\n", Stu[i].Stuid, Stu[i].Stuname, Stu[i].Stuage, Stu[i].Stusex, Stu[i].score[0], Stu[i].score[1], Stu[i].score[2]);
				printf("**************************************************\n");
				printf("----1.修改学生性别             2.修改学生姓名-----\n");
				printf("----3.修改学生年龄             4.修改C语言成绩----\n");
				printf("----5.修改高数成绩             6.修改大物成绩-----\n");
				printf("********************7.退出本菜单******************\n");
				printf("请输入你要修改的选项:\n");
				scanf("%d", &input);
				switch (input)
				{
				case 1:
					printf("请输入要修改的性别:\n");
					scanf("%s", sex);
					strcpy(Stu[i].Stusex, sex);
					break;
				case 2:
					printf("请输入要修改的姓名:\n");
					scanf("%s",name);
					strcpy(Stu[i].Stuname, name);
					break;
				case 3:
					printf("请输入要修改的年龄:\n");
					scanf("%d", &age);
					Stu[i].Stuage = age;
					break;
				case 4:
					printf("请输入要修改的C语言成绩:\n");
					scanf("%lf", &score);
					Stu[i].score[0] = score;
					break;
				case 5:
					printf("请输入要修改的高数成绩:\n");
					scanf("%lf", &score);
					Stu[i].score[1] = score;
					break;
				case 6:
					printf("请输入要修改的大物成绩:\n");
					scanf("%lf", &score);
					Stu[i].score[2] = score;
					break;
				case 7:
					return;
				default:
					printf("选择错误,请重新选择!\n");
					break;
				}
			}
			if (1 <= input && input <= 6)
			{
				printf("恭喜你修改成功!\n");
				break;
			}
			
			if (flag == 0)
			{
				printf("没有找到该学生信息,请重新输入学生学号:\n");
				gets(name);
			}
		}
	}
	system("pause");
}

int PaiXu(const void* e1, const void* e2)
{
	return  ((struct Student*)e2)->score[0] - ((struct Student*)e1)->score[0];
}
int PaiXu1(const void* e1, const void* e2)
{
	return  ((struct Student*)e2)->score[0] - ((struct Student*)e1)->score[0];
}
int PaiXu2(const void* e1, const void* e2)
{
	return  ((struct Student*)e2)->score[2] - ((struct Student*)e1)->score[2];
}
void PaiMing()
{
	int input = 0;
	while (1)
	{
		printf("\t\t**************************************************\n");
		printf("\t\t---------------------***光荣榜***-----------------\n");
		printf("\t\t**************************************************\n");
		printf("\t\t********1.C语言-------------------2.高数**********\n");
		printf("\t\t********3.大物--------------------4.退出系统******\n");
		printf("\t\t**************************************************\n");
		printf("请输入你要查询的排名:\n");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			printf("\t学号:\t\t名字:\tC语言成绩:\n");
			int rs = sizeof(Stu) / sizeof(Stu[0]);
			qsort(Stu, rs, sizeof(Stu[0]), PaiXu);//排序
			for (int i = 0; i < m; i++)
			{
				printf("第%d名\t%s\t%s\t%.2lf", i+1, Stu[i].Stuid, Stu[i].Stuname, Stu[i].score[0]);
				printf("\n");
			}
			break;
		case 2:
			printf("\t学号:\t\t名字:\t高数成绩:\n");
			int rs1 = sizeof(Stu) / sizeof(Stu[0]);
			qsort(Stu, rs1, sizeof(Stu[0]), PaiXu1);
			for (int i = 0; i < m; i++)
			{
				printf("第%d名\t%s\t%s\t%.2lf", i+1, Stu[i].Stuid, Stu[i].Stuname, Stu[i].score[0]);
				printf("\n");
			}
			break;
		case 3:
			printf("\t学号:\t\t名字:\t大物成绩:\n");
			int rs2 = sizeof(Stu) / sizeof(Stu[0]);
			qsort(Stu, rs, sizeof(Stu[0]), PaiXu2);
			for (int i = 0; i < m; i++)
			{
				printf("第%d名\t%s\t%s\t%.2lf", i+1, Stu[i].Stuid, Stu[i].Stuname, Stu[i].score[0]);
				printf("\n");
			}
			break;
		case 4:
			return;
		default:
			printf("选择错误,重新选择!\n");
			break;
		}
	}
}
int sum = 1;
int main()
{
	int i = 0;
	int input = 0, count = 0;
	char mima[20] = "123";//登入的密码
	char shuru[20];
	char mingzi[20];
	system("color F4");
	printf("\t\t\t     **************************************\n");
	printf("\t\t\t     |       *欢迎使用学生管理系统*       |\n");
	printf("\t\t\t     |           *管理员: 小唐*           |\n");
	printf("\t\t\t      ------------------------------------\n");
	printf("请输入管理员密码:\n");
	while ((count = _getch()) != '\r')
	{
		if (count == '\b')
		{
			i--;
			printf("\b \b");
		}
		else
		{
			shuru[i++] = count;
			printf("*");
		}
	}
	shuru[i++] = '\0';   
	if (strcmp(mima, shuru) == 0)
	{
		printf("\n密码正确,您已进入系统!\n");
	}
	else
	{
		printf("\n密码错误,请重新输入!\n");
		return 0;
	}
	system("pause");
	system("cls");
	do
	{
		menu2();
		printf("请选择继续还是结束操作:\n");
		scanf("%d", &sum);
		switch (sum)
		{
		case Quit:
			system("cls");
			printf("您已退出学生管理系统!\n");
			break;
		case Resume:
			menu1();
			void(*p[9])() = { NULL,TiShi,StuXinXi,ChaZhao,ShanGai,BaoCun,XianShi,XiuGai,PaiMing };//指针数组函数
			printf("请输入你要进行的操作\n");
			scanf("%d", &input);
			system("cls");
			(*p[input])();
			break;
		default:
			printf("输入错误,重新输入!\n");
			break;
		}
	} while (sum);
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/230975.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

clickhouse数据库磁盘空间使用率过高问题排查

一、前言 clickhouse天天触发磁盘使用率过高告警&#xff0c;所以需要进行排查&#xff0c;故将排查记录一下。 二、排查过程 1、连接上进入clickhouse 2、执行语句查看各库表使用磁盘情况 SELECT database, table, formatReadableSize(sum(bytes_on_disk)) as disk_space F…

Leetcode—2034.股票价格波动【中等】

2023每日刷题&#xff08;五十二&#xff09; Leetcode—2034.股票价格波动 算法思想 实现代码 class StockPrice { public:int last 0;multiset<int> total;unordered_map<int, int> m;StockPrice() {}void update(int timestamp, int price) {if(m.count(time…

TrustZone之Translation Look aside Buffer(TLB)

TLB缓存最近使用的地址转换。处理器具有多个独立的translation regimes。TLB记录了一个条目表示的translation regime&#xff0c;包括安全状态。虽然TLBs的结构是由实现定义的&#xff0c;但以下图表显示了一个示例&#xff1a; 当软件在EL1或EL2中发出TLB失效操作&#xff08…

Zabbix补充

Zabbix的自动发现机制&#xff1a; Zabbix客户端主动和服务端联系&#xff0c;将自己的地址和端口发送服务端&#xff0c;来实现自动添加主机 客户端是自动的一方 缺点&#xff1a;自定义的网段的主机数量太多&#xff0c;登记耗时会很久&#xff0c;而且这个自动发现机制不是…

已通过考试和认证注册以及后续计划表

已通过考试和认证注册以及后续计划表 软考 - 计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试信息系统集成及服务项目管理人员工程类考试计划你关注的证书样子 软考 - 计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试 高级 信息系统项目管理师&…

【接口技术】实验4:定时器与计数器

实验4 定时器与计数器实验 一、实验目的 1&#xff1a;掌握8253的计数特点和编程方法。 2&#xff1a;掌握8253各类工作方式的基本工作原理。 3&#xff1a;掌握PC机中断处理系统的基本原理。 4&#xff1a;学会编写中断服务程序。 二、实验内容 1&#xff1a;8254计数器…

Java+Swing: 主界面的窗体 整理8

主界面的写法跟之前登录界面的窗体写法大致相同&#xff0c;在主界面中主要是窗体的大小的设置 package com.student_view;import com.utils.DimensionUtil; import sun.applet.Main;import javax.swing.*; import java.awt.*; import java.net.URL;/*** Author&#xff1a;xie…

【C++ Primer Plus学习记录】if语句

目录 一、if语句 二、if else语句 三、格式化if else语句 四、if else if else结构 一、if语句 if语句让程序能够决定是否应执行特定的语句。 if有两种格式&#xff1a;if和if else。 if语句的语法与while相似&#xff1a; if(test-condition)statement; 如果test-con…

贝锐花生壳3大安全能力,保障网络服务安全远程连接

在没有公网IP的情况下&#xff0c;使用内网穿透工具&#xff0c;将本地局域网服务映射至外网&#xff0c;虽然高效快捷&#xff0c;但信息安全也是不可忽略的方面。 对此&#xff0c;贝锐花生壳提供了多维度的安全防护能力&#xff0c;满足不同场景下用户安全远程访问内网服务的…

【IO流(1)】——基于字节流实现的文件复制及资源释放新写法

文章目录 IO流基于字节流复制文件IO流概述FileInputStream读取一个字节FileInputStream读取多个字节FileInputStream读取全部字节FileOutStream写字节 IO流资源释放JDK7以前的资源释放JKD7之后的资源释放 IO流 基于字节流复制文件 需求&#xff1a;复制一张图片&#xff0c;从…

hook其他调试技巧

输出堆栈信息 通过 android.util.Log 输出当前线程的堆栈跟踪信息。 function showStacks() {Java.perform(function () {console.log(Java.use("android.util.Log").getStackTraceString(Java.use("java.lang.Throwable").$new() )); }) } 可以在需要的…

基于ssm平面设计课程在线学习平台系统源码和论文

idea 数据库mysql5.7 数据库链接工具&#xff1a;navcat,小海豚等 随着信息化时代的到来&#xff0c;管理系统都趋向于智能化、系统化&#xff0c;平面设计课程在线学习平台系统也不例外&#xff0c;但目前国内的市场仍都使用人工管理&#xff0c;市场规模越来越大&#xff0c;…

如何恢复已删除的 JPG/JPEG 文件的方法深度解析!

您是否意外丢失或删除了 JPG 或 JPEG 照片&#xff1f;幸运的是&#xff0c;您可以使用照片恢复工具将它们恢复。立即获取适用于 PC 的 JPEG 恢复工具 - 照片恢复&#xff1a; 照片是捕捉和重温生活中特殊时刻的最佳方式。因此&#xff0c;当我们由于硬盘崩溃、意外格式化磁盘…

Java实现快速排序算法

快速排序算法 &#xff08;1&#xff09;概念&#xff1a;快速排序是指通过一趟排序将要排序的数据分割成独立的两部分&#xff0c;其中一部分的所有数据都比另外一部分的所有数据都要小&#xff0c;然后再按此方法对这两部分数据分别进行快速排序。整个排序过程可以递归进行&…

No suitable driver found for jdbc:mysql://localhost:3306(2023/12/8更新)

有两种情况&#xff1a; 压根没安装下载了但没设为库或方法不对 看到这里看过另一篇解决方法的友友该疑惑了&#xff0c;咋跟上一篇文案一样呢 别急&#xff0c;这里的区别在于安装方法&#xff0c;这次提供的方法更为通用 大多数为第一种情况&#xff1a; 一. 下载jdbc 打开…

【C++】:搜索二叉树

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家解读一下有关多态的知识点&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; C 语 言 专 栏&#xff1a;C语言&#xff1a;从入门到精通 数据结…

uniapp实战 —— 轮播图【数字下标】(含组件封装,点击图片放大全屏预览)

组件封装 src\components\SUI_Swiper2.vue <script setup lang"ts"> import { ref } from vue const props defineProps({config: Object, })const activeIndex ref(0) const change: UniHelper.SwiperOnChange (e) > {activeIndex.value e.detail.cur…

小红书品牌投放须知,家居产品软文怎么写?

家居产品软文&#xff0c;是一种展示家居产品的文案写作形式。优秀的家居产品软文能够通过引人入胜的文字&#xff0c;吸引受众的注意力并激发他们选购家居产品的兴趣。今天我们来为大家分享一下小红书品牌投放须知&#xff0c;家居产品软文怎么写&#xff1f; 一、关键词布局 …

[mysql]linux安装mysql5.7

之前安装的时候遇到了很多问题&#xff0c;浪费了一些时间。整理出这份教程&#xff0c;照着做基本一遍过。 这是安装包: 链接&#xff1a;https://pan.baidu.com/s/1gBuQBjA4R5qRYZKPKN3uXw?pwd1nuz 1.下载安装包&#xff0c;上传到linux。我这里就放到downloads目录下面…

认知觉醒(六)

认知觉醒(六) 第二节 感性&#xff1a;顶级的成长竟然是“凭感觉” 人类生存于世&#xff0c;比拼的是脑力思维&#xff0c;但极少有人知道&#xff0c;我们的身体里还有一个更高级的系统&#xff0c;若能善用&#xff0c;成就非凡。 1941年&#xff0c;德军对英国本土进行…