C语言实现学生成绩管理系统设计

C语言实现学生成绩管理系统设计本系统有**增加学生记录、修改学生记录、删除学生记录、按姓名查询学生记录、按C语言成绩对学生进行排序、退出系统**6大功能。能够对学生的姓名,学号,c语言成绩做相应的操作。在检测到输入成绩大于55时,会自动加上5。该管理系统设计功能模块图:下面是源代码:#include”stdio.h”#include”string”/*定义学生结构体*/structStudent

大家好,又见面了,我是你们的朋友全栈君。

本系统有增加学生记录、修改学生记录、删除学生记录、按姓名查询学生记录、按C语言成绩对学生进行排序、退出系统6大功能。
能够对学生的姓名,学号,c语言成绩做相应的操作。
在检测到输入成绩大于55时,会自动加上5。

该管理系统设计功能模块图:
C语言实现学生成绩管理系统设计

下面是源代码:

#include "stdio.h"  
#include "string.h"

/*定义学生结构体*/  
struct Student
{
     char ID[20];		//学号
     char Name[20];		//姓名
     float C_Mark;		//C语言成绩
};
  
/*声明学生数组及学生数量*/  
struct Student students[1000];  
int num=0;  
  
/*通过学号返回数组下标*/   
int Student_SearchByIndex(char id[])  
{
	int i;  
	for (i=0;i<num;i++)  
    {
		if (strcmp(students[i].ID,id)==0)  
        {
			return i;  
        }  
    }  
	return -1;   
}
  
/*通过姓名返回数组下标*/
int Student_SearchByName(char name[])  
{
	int i;  
	for (i=0;i<num;i++)  
	{ 
		if (strcmp(students[i].Name,name)==0)
		{ 
			return i;
		}  
    }  
	return -1;  
}  

/*显示单条学生记录*/  
void Student_DisplaySingle(int index)   
{
	printf("%10s%10s%8s\n","学号","姓名","C语言成绩");  
    printf("-------------------------------------------------------------\n");  
    printf("%10s%10s%8.2f\n",students[index].ID,students[index].Name,students[index].C_Mark);  
}  

/****1、增加学生记录*****/  
void Student_Insert()  
{  
	while(1)  
	{
		printf("请输入学号:");  
		scanf("%s",&students[num].ID);  
		getchar();  
		printf("请输入姓名:");  
		scanf("%s",&students[num].Name);  
		getchar(); 
		printf("请输入C语言成绩:");  
		scanf("%f",&students[num].C_Mark);  
	    getchar(); 
		if (54<students[num].C_Mark && students[num].C_Mark< 60)	//把55~59分之间的成绩都加上5分
		{
			students[num].C_Mark += 5;		
		}

		num++;

        printf("是否继续?(Y/N),继续请按任意键,否则输入N:"); 
		if (getchar()=='N')  
		{  
			break;
        }  
     }  
}     
  
/******2、修改学生信息**********/  
void Student_Modify()  
{  
	while(1) 
	{  
		char id[20]; 
		int index; 
		printf("请输入要修改的学生的学号:"); 
		scanf("%s",&id);  
		getchar();  
		index=Student_SearchByIndex(id);  
		if (index==-1)  
        {  
			printf("该学生不存在!\n"); 
         }
		else  
		{  
			printf("你要修改的学生信息为:\n"); 
			Student_DisplaySingle(index);  
			printf("-- 请输入新值--\n"); 
			printf("请输入学号:");  
			scanf("%s",&students[index].ID);  
			getchar();  
			printf("请输入姓名:");  
			scanf("%s",&students[index].Name);  
			getchar();  
			printf("请输入C语言成绩:");  
			scanf("%f",&students[index].C_Mark);  
			getchar();  
			
         }  
  
         printf("是否继续?(Y/N),继续请按任意键,否则输入N:"); 
		 if (getchar()=='N')  
		 {  
			break;
         }  
  
     }  
  
} 
  
/****3、删除学生信息****/  
void Student_Delete()  
{ 
	int i;  
	while(1)  
	{  
		char id[20];  
		int index;  
		printf("请输入要删除的学生的学号:");  
		scanf("%s",&id);  
		getchar();  
		index=Student_SearchByIndex(id);  
		if (index==-1)  
		{  
			printf("学生不存在!\n");  
		}  
		else  
		{  
			printf("你要删除的学生信息为:\n"); 
			Student_DisplaySingle(index);  
			printf("是否真的要删除?(Y/N)");  
			if (getchar()=='Y')  
			{  
				for (i=index;i<num-1;i++)  
				{  
					students[i]=students[i+1];//把后边的对象都向前移动  
				} 
				num--;  
             }  
			getchar();  
			printf("已删除\n");
         }  
  
         printf("是否继续删除?(Y/N),继续请按任意键,否则输入N:"); 
		 if (getchar()=='N')  
		 {  
			break;
         }  
     }  
}  
  
   
/****4、按姓名查询******/  
void Student_Select()  
{  
	while(1)  
	{  
		char name[20];  
		int index;  
  
		printf("请输入要查询的学生的姓名:");  
		scanf("%s",&name); 
		getchar();  
		index=Student_SearchByName(name);  

        if (index==-1) 
		{  
			printf("学生不存在!\n"); 
		} 
		else  
		{  
			printf("你要查询的学生信息为:\n"); 
			Student_DisplaySingle(index);  
		}  
  
		printf("是否继续?(Y/N),继续请按任意键,否则输入N:"); 
		if (getchar()=='N')  
		{  
			break;
        } 
  
     }
}  
  
   
  
/******5、按C语言成绩排序*******/  
void Student_SortByAverage()  
{  
	int i,j;  
	struct Student tmp;  
  
	for (i=0;i<num;i++)  
	{  
		for (j=1;j<num-i;j++) 
		{  
			if (students[j-1].C_Mark<students[j].C_Mark) 
			{  
				tmp=students[j-1]; 
				students[j-1]=students[j];  
				students[j]=tmp;  
			}  
		}  
	}  
}  
  

/*显示学生信息*/  
void Student_Display()  
{  
	int i;  
	printf("%10s%10s%8s\n","学号","姓名","成绩");  
	printf("-------------------------------------------------------------\n");  
  
	for (i=0;i<num;i++)  
	{  
		printf("%10s%10s%8.2f\n",students[i].ID,students[i].Name,students[i].C_Mark);  
	}  

}  
  
/*将学生信息从文件(Database.txt)中读出*/  
void IO_ReadInfo()  
{ 
	FILE *fp;  
	int i;  
  
	if ((fp=fopen("Database.txt","rb"))==NULL)  
	{  
		printf("不能打开文件!\n");  
		return;  
	}
	
	if (fread(&num,sizeof(int),1,fp)!=1)  
	{  
		num=-1;  
	} 
	else  
	{  
		for(i=0;i<num;i++)  
		{  
			fread(&students[i],sizeof(struct Student),1,fp);  
		}  
	} 
	
	fclose(fp);  
} 
  
/*将学生信息写入文件(Database.txt)*/  
void IO_WriteInfo()
{  
	FILE *fp; 
	int i;  
	if ((fp=fopen("Database.txt","wb"))==NULL)  
	{  
		printf("不能打开文件!\n");  
		return;  
	}  
	if (fwrite(&num,sizeof(int),1,fp)!=1)  
	{  
		printf("写入文件错误!\n");  
	}  
	for (i=0;i<num;i++)  
	{  
		if (fwrite(&students[i],sizeof(struct Student),1,fp)!=1)  
		{  
			printf("写入文件错误!\n");  
		}  
	}  
	fclose(fp);  
} 

/***********主程序*********/ 
void main()  
{ 
	int choice;  
 
	IO_ReadInfo();			//读取文件

	while(1)  
	{  
		/*主菜单*/  
		printf("\n------ 学生成绩管理系统------\n");  
		printf("1. 增加学生记录\n");  
		printf("2. 修改学生记录\n");  
		printf("3. 删除学生记录\n");  
		printf("4. 按姓名查询学生记录\n");  
		printf("5. 按C语言成绩排序\n");  
		printf("6. 退出\n");  
		printf("请选择(1-6):");  
  
		scanf("%d",&choice);  
		getchar();  
  
		switch(choice)  
		{ 
		case 1:  
			Student_Insert();  
			break; 

		case 2: 
			Student_Modify(); 
			break;  
  
		case 3:  
			Student_Delete(); 
			break;  
  
		case 4:  
			Student_Select();
			break;  
  
		case 5:  
			Student_SortByAverage();
			Student_Display();
			break;  
  
		case 6: 
			exit(0);  
			break;  
		} 
		IO_WriteInfo();  
  
	} 
}  

运行结果:
测试第一个功能,输入四个学生的成绩:
C语言实现学生成绩管理系统设计

测试第二个功能,修改学生记录:
C语言实现学生成绩管理系统设计

测试第三个功能,删除学生记录:
C语言实现学生成绩管理系统设计

测试第四个功能,按姓名查询学生记录:
C语言实现学生成绩管理系统设计

测试第五个功能,显示所有学生的成绩,按照C语言成绩由高到底排序:
C语言实现学生成绩管理系统设计

我们可以看到,各项功能的实现,在第2个步骤中,将赵的成绩改为80,而第3个步骤删除了李的成绩。从第5个步骤中可以看出,我们输入的张是56分,输出按照事先设定好的加上5变成了61分。系统的稳定正在测试中,按照原计划实现了功能。

本系统的整个开发过程和功能实现,能够进行学生C语言成绩信息录入、修改、删除、查询、浏览操作,本系统的应用,将会使学生和教务管理人员在第一时间内获得理想的信息。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151550.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C++ docker_docker部署mysql

    C++ docker_docker部署mysql版权声明:本文为博主原创文章,未经博主允许不得转载。Docker介绍Docker是一个开源的容器引擎,它有助于更快地交付产品。Docker可将应用程序和基础设施层隔离,并且将基础设施当作程序一样进行管理。使用Docker,可以更快地打包,测试以及部署应用程序,并可以缩短从编程到部署运行代码的周期docker部署c/c++程序关于docker的使用网上有很多的教程但是很少有介绍如…

    2022年10月19日
    2
  • Oracle列转行函数LISTAGG() WITHIN GROUP ()的使用方法

    Oracle列转行函数LISTAGG() WITHIN GROUP ()的使用方法前言:最近在写一些比较复杂的SQL,是一些统计分析类的,动不动就三四百行,也是首次写那么长的SQL,有用到一些奇形怪状的SQL函数,在这里结合网上的例子做一些笔记,以后用到不记得用法可以翻出来看!1.基础用法:LISTAGG(XXX,XXX)WITHINGROUP(ORDERBYXXX),就像聚合函数一样,通过Groupby语句,把每个Group的一个字段,拼接起来…

    2025年8月3日
    1
  • 二叉树abcdefghij先序遍历_二叉树后序遍历的非递归算法

    二叉树abcdefghij先序遍历_二叉树后序遍历的非递归算法给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。题解深搜/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() :

    2022年8月9日
    9
  • python进制转换函数

    python进制转换函数一:二,八,十六进制转十进制注意2进制对应的数值范围只能是0和1,超过范围会报错,8进制和16进制同理。print(int(‘100′,2))#二进制转十进制,int(’20’,2)会报错print(int(’30’,8))#八进制转十进制,int(’80’,8)会报错print(int(‘f0’,16))#十六进制转十进制,int(‘g0’,16)会报错二:十进制转二进制、八进制、十六进制。内置函数bin、oct、hex得到的进制前面会分别带有’0b’,‘0o’,’0x’字符。

    2022年5月12日
    67
  • 浅谈 JMeter 运行原理

    浅谈 JMeter 运行原理

    2021年7月13日
    95
  • MySQL中聚集索引、非聚集索引、联合索引、覆盖索引[通俗易懂]

    MySQL中聚集索引、非聚集索引、联合索引、覆盖索引[通俗易懂]在《面试官:为啥加了索引查询会变快?》一文中,我们介绍了索引的数据结构,正是因为索引使用了B+树,才使得查询变快。说白了,索引的原理就是减少查询的次数、减少磁盘IO,达到快速查找所需数据的目的我们一起来看一下InnoDB存储引擎中的索引聚集索引聚集索引(clusteredindex)就是按照每张表的主键构造一棵B+树,同时叶子节点中存放的即为整张表的行记录数据,也将聚集索引的叶子节点称为数据页。聚集索引的这个特性决定了索引组织表中数据也是索引的一部分(备注:真实的B+树叶子节点是通过链表相连的,

    2022年6月4日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号