C语言学生管理系统完善版
#include<stdio.h>
#include<string.h>
#include <stdlib.h>
#define M 100
struct score                                    //学生成绩信息结构体定义 
{
	int china;
	int english;
	int math;
	int  add;
	
};
struct info     //学生信息结构体定义
{
	int num;            //学生学号5
	char name[10];      //学生姓名
	struct score mark;       //学生成绩 
   
};
float guake[10];                         //定义一个各科挂科率 
float aver[10];                     //定义一个各科平均分 
struct info student[M];           //定义一个全局数组student,用来存放学生信息,最多存放100个学生。
char ch[20]={"物联1161学生信息"};                                         //定义一个数据库文件名称 
int count=0;                                    //存放实际输入的学生人数
int input(struct info st[]) ;                   //录入学生信息函数声明
void show(struct info st[],int n) ;             //显示学生信息函数声明
int del(struct info st[],int n);                //删除学生信息函数声明
int add_up(struct info st[],int n);                //统计学生信息函数声明
void change(struct info st[],int n);            // 修改学生信息函数声明
void search(struct info st[],int n);            //查询学生信息函数声明
void read();                                    //遍历以往学生信息数据库声明 
void write();                                     //用于修改和删除 重新写入数据库 
void all_del();                                    //清空以往所有学生信息 
void add_date();                                    //自定义学生信息存储文件库
void read_date();                                   //打开自定义学生信息存储文件库 
char b[20]={"物联1161学生信息"};                                   //保存文件名称 用于打开失败 原名称变回 
main()
{
int select;
  system("color E");
    read();
	while(1)
	{
		system("cls");
		printf("\t ******************欢迎使用******************\n");
		printf("\t **************学生信息管理系统**************\n");
		printf("\t  *--------------作者:徐伟明--------------*\n");
		printf("\t  *         1--录入/增加学生信息           *\n");
		printf("\t  *         2--显示学生信息                *\n");
		printf("\t  *         3--查询学生信息                *\n");
		printf("\t  *         4--修改学生信息                *\n");
		printf("\t  *         5--统计学生信息                *\n");
		printf("\t  *         6--删除学生信息                *\n");
	    printf("\t  *         7--清空数据库的学生信息        *\n");
	    printf("\t  *         8--自定义存储学生信息文件库    *\n");
	    printf("\t  *         9--打开自定义存储学生信息文件库*\n");
	    printf("\t  *         0--退出                        *\n");
		printf("\t *------------------------------------------*\n");
		printf("\t *目前存储信息文件名为<<%s>>*\n",ch);
		printf("\t 你要输入的功能号是(0--9):");
		scanf("%d",&select);
		if(select==0) break;
		switch(select){
		              case 1: count=input(student); //调用input函数录入数据
			break;
		              case 2: show(student,count); //调用show函数显示学生信息
			system("pause");
			break;
		              case 3: search(student,count);  //调用search函数查询学生信息
			system("pause");
						break;
		              case 4: change(student,count);  //调用change函数修改学生信息
			system("pause");
						break;
		              case 5: count=add_up(student,count);     //调用add_up函数统计学生信息
			system("pause");
						break;
	
			          case 6: count=del(student,count);    // 调用del函数删除学生信息
			system("pause");
			break;
			          case 7: all_del();    // //清空以往学生信息数据库声明 
			system("pause");
			break;
			          case 8: add_date();    // //自定义增加数据库声明 
			system("pause");
			break;
			          case 9: read_date();    // //打开自定义增加数据库声明 
			system("pause");
			break;
		           	  case 0: exit(0);    // //打开自定义增加数据库声明 
			system("pause");
			break;
					default:printf("没有此选项,请重新选择!\n");	system("pause");	
					getchar();
		}
	}
}
void all_del()
{
	int a=0;
         FILE *fp;
         printf("请输入欲清空文件库名:");
         strcpy(b,ch);
         scanf("%s",&ch);
		if((fp=fopen(ch,"rb"))==NULL)
		{
			printf("清空失败~~未发现文件名%s\n",ch);
			strcpy(ch,b);
			fclose(fp);
			goto end;
		}
		fclose(fp);
		fp=fopen(ch,"wb");
		strcpy(ch,b);
	     fp=fopen(ch,"rb");
			while(fread(&student[a],sizeof(struct info),1,fp)!=0)
	{
		a++;
	}   
	count=a;
		printf("成功清除%s所有学生信息\n\n",ch);
	fclose(fp);
	end:;
 } 
 
void read()
{
	int a=0;
	
         FILE *fp;
		if((fp=fopen(ch,"rb"))==NULL)
		{
			printf("~~~~~~~~~~~~~~!!!!!!!!!!未发现该文件!!!!!!!!!!~~~~~~~~~~~~~~");
			
            strcpy(ch,b);
	     fclose(fp);
			goto end; 
		}
			while(fread(&student[a],sizeof(struct info),1,fp)!=0)
	{
		a++;
	}   
	count=a;
	fclose(fp);
	printf("··············恭喜遍历%s成功················\n",ch); 
	end:;
} 
void write()                                                        //格式化文件 重新录入所有信息 
{
	FILE *fp;
	int i;
	if((fp=fopen(ch,"wb"))==NULL)
	{
		printf("error");
		exit(0);
	}
	for(i=0;i<count;i++)
	{
		if(fwrite(&student[i],sizeof(struct info),1,fp)!=1)
		{
			printf("error");
			fclose(fp);
		}
	}
	fclose(fp);
 } 
void add_date()
 {
 	FILE *fp;
 	int a=0;
 	printf("请输入数据库文件名称:");
 	scanf("%s",&ch);
 	if(!(fp=fopen(ch,"wb")))
 	{
 		printf("cannoe open the file");
	 }
	 fclose(fp);
	 fp=fopen(ch,"rb");
			while(fread(&student[a],sizeof(struct info),1,fp)!=0)
	{
		a++;
	}   
	count=a;
	printf("···················成功创建数据库%s···················\n",ch); 
	fclose(fp);
 }
 
 void read_date()
 {
 	printf("输入你下要打开数据库名称:"); 
 	strcpy(b,ch);
 	scanf("%s",&ch);
 	char b[20]={"a"};
 	read();
 }
int input(struct info st[]) //录入学生信息的函数
{
char sel;
FILE *fp;
	
	if((fp=fopen(ch,"ab+"))==NULL)
	{
		printf("sfsdf");
		exit(0);
	}
  int i=count;                                
do
  {
	
	printf("\n请输入第%d个学生信息:\n",i+1);
	printf("\t学生学号:");
	scanf("%d",&st[i].num);
	printf("\t学生姓名:");
	scanf("%s",&st[i].name);
	printf("\t语文成绩:");
	scanf("%d",&st[i].mark.china);
	printf("\t英语成绩:");
	scanf("%d",&st[i].mark.english);
	printf("\t数学成绩:");
	scanf("%d",&st[i].mark.math);
	st[i].mark.add=st[i].mark.china+st[i].mark.english+st[i].mark.math;
	if(fwrite(&student[i],sizeof(struct info),1,fp)!=1)         //录入数据库 
		printf("error");
	i++;
	printf("\n是否要继续录入学生信息(Y/N):");
	getchar();                               //此处是读走缓冲区的换行符	
	sel=getchar();     
}while(sel=='Y' || sel=='y' ); 
fclose(fp);                                  //关闭文件 
return i;
}
void show(struct info st[],int n)               //显示所有学生信息函数
{
	int i,j,min;
	 for(i=0;i<count-1;i++)                            //步骤:学号排序 
	  {   min=i;                 
     
     	for(j=i+1;j<count;j++)
     	if(st[min].num>st[j].num)
     	{
     		st[99]=st[min]; st[min]=st[j]; st[j]=st[99];
		 }
	 }
	printf("\n\n%-10s%-15s%-10s%-10s%-10s%-10s\n","学生学号","学生姓名","语文","英语","数学","总分");
	for(i=0;i<n;i++)
	{
		 printf("\n%-10d%-15s%-10d%-10d%-10d%-10d\n",st[i].num,st[i].name,st[i].mark.china,st[i].mark.english,st[i].mark.math,st[i].mark.add);
	}
	printf("\n");
}
void search(struct info st[],int n)                   //根据学号查询学生信息 
{
	int num,i;
printf("\n\n请输入需要查询的学号:");
scanf("%d",&num);
for(i=0;i<count;i++)
{
	if(num==st[i].num) 
	{
	printf("\n\n%-10s%-15s%-10s%-10s%-10s%-10s\n",
	"学生学号","学生姓名","语文","英语","数学","总分");
	printf("\n%-10d%-15s%-10d%-10d%-10d%-10d\n",st[i].num,st[i].name,st[i].mark.china,st[i].mark.english,st[i].mark.math,st[i].mark.add);
	}
    
}
return;
}
void change(struct info st[],int n)                                     //修改学生信息 
{
	int num,i;
	printf("\n\n%-10s%-15s%-10s%-10s%-10s%-10s\n",
	"学生学号","学生姓名","语文","英语","数学","总分");
	for(i=0;i<count;i++)
{		
	printf("\n%-10d%-15s%-10d%-10d%-10d%-10d\n",st[i].num,st[i].name,st[i].mark.china,st[i].mark.english,
	st[i].mark.math,st[i].mark.add);   
}
printf("\n\n请输入需要修改信息的学号:");
scanf("%d",&num);
for(i=0;i<count;i++)
{
	if(num==st[i].num) 
	{
	printf("\n%-10s%-15s%-10s%-10s%-10s%-10s\n",
	"学生学号","学生姓名","语文","英语","数学","总分");
	printf("\n%-10d%-15s%-10d%-10d%-10d%-10d\n",st[i].num,st[i].name,st[i].mark.china,st[i].mark.english,st[i].mark.math,st[i].mark.add);break;
	}
	if(i==count-1){  printf("修改失败~未发现学号%d\n",num);goto end;}
 }
    printf("\n请输入学号为%d学生信息:\n",st[i].num);
	printf("\t学生学号:");
	scanf("%d",&st[i].num);
	printf("\t学生姓名:");
	scanf("%s",&st[i].name);
	printf("\t语文成绩:");
	scanf("%d",&st[i].mark.china);
	printf("\t英语成绩:");
	scanf("%d",&st[i].mark.english);
	printf("\t数学成绩:");
	scanf("%d",&st[i].mark.math);
	getchar();
	printf("。。。。。。。。。。。修改成功。。。。。。。。。。。。\n"); 
	write();
	end:;
}
int add_up(struct info st[],int n)                     //统计学生信息 
{
	int a,b,c,d,e,f;
     int i,j,max;
     float add=0.0,g=0.0;
     for(i=0;i<count-1;i++)                            //步骤:总分排序 
	  {   max=i;                 
     
     	for(j=i+1;j<count;j++)
     	if(st[max].mark.add<st[j].mark.add)
     	{
     		st[99]=st[max]; st[max]=st[j]; st[j]=st[99];
		 }
	 }
     
     
     	printf("\n%-10s%-15s%-10s%-10s%-10s%-10s%-10s\n",
	"学生学号","学生姓名","语文","英语","数学","总分","名次");
	max=1;
     for(i=0;i<count;i++)
    {	
	printf("\n%-10d%-15s%-10d%-10d%-10d%-10d%-10d\n",st[i].num,st[i].name,st[i].mark.china,st[i].mark.english,st[i].mark.math,st[i].mark.add,max++);
    }
     for(i=0;i<count;i++)                                                           //步骤:统计平均分 
     add=st[i].mark.china+add;
     aver[0]=add/count;
     
	 add=0;
     for(i=0;i<count;i++)
     add+=st[i].mark.english;
     aver[1]=add/count;
     
     add=0;
     for(i=0;i<count;i++)
     add+=st[i].mark.math;
     aver[2]=add/count;
     
	 printf("             平均分:  \t%-10.2f%-10.2f%-10.2f\n",aver[0],aver[1],aver[2]) ;   
	 
	 
	 for(i=0;i<count;i++)                                              //步骤: 统计各科挂科率 
	 {if(st[i].mark.china<60)  g++; } guake[0]=(g/count)*100;
	 g=0;
	 for(i=0;i<count;i++)
	 {if(st[i].mark.english<60)  g++; } guake[1]=(g/count)*100;
	 g=0;
	 for(i=0;i<count;i++)
	 {if(st[i].mark.math<60)  g++; }   guake[2]=(g/count)*100;
	 
	 printf("             挂科率:  \t%-10.2f%-10.2f%-10.2f\n",guake[0],guake[1],guake[2]) ; 
	 
	 printf("\n\n各科状元郎:\n");
	 printf("\n%-10s%-15s%-15s%-10s\n","状元科目","分数","姓名","学号");
	                          
	      a=0;                 
     	for(j=1;j<count;j++)                                               //步骤: 通过打雷法寻最高分 
     	if(st[a].mark.china<st[j].mark.china) a=j;
     	 
		  b=0;                 
     	for(j=1;j<count;j++)
     	if(st[b].mark.english<st[j].mark.english)
     	{
     	    b=j;
		 }
		 
		  c=0;                 
     	for(j=1;j<count;j++)
     	if(st[c].mark.math<st[j].mark.math)
     	{
     	    c=j;
		 }
		 printf("%-10s%-15d%-15s%-10d \n","语文",st[a].mark.china,st[a].name,st[a].num);
	     printf("%-10s%-15d%-15s%-10d \n","英语",st[b].mark.english,st[b].name,st[b].num);
	     printf("%-10s%-15d%-15s%-10d \n","数学",st[c].mark.math,st[c].name,st[c].num);
	                         
     return i;
}
int del(struct info st[],int n)                 //删除学生信息 
{
		int num,i;
	printf("\n\n%-10s%-15s%-10s%-10s%-10s%-10s\n",
	"学生学号","学生姓名","语文","英语","数学","总分");
	for(i=0;i<count;i++)
{		
	printf("\n%-10d%-15s%-10d%-10d%-10d%-10d\n",st[i].num,st[i].name,st[i].mark.china,st[i].mark.english,
	st[i].mark.math,st[i].mark.add);   
}
printf("\n\n请输入需要删除信息的学号:");
scanf("%d",&num);
for(i=0;i<count;i++)
{
	if(num==st[i].num) break;
	if(i==count-1) {printf("删除失败~未发现学号%d\n",num);goto end;}
}
for(;i<count-1;i++)
{
	st[i]=st[i+1];
}
count--;
printf("。。。。。。。。。。。删除成功。。。。。。。。。。。。\n"); 
write();
     end:
    return i;
}
C语言学生管理系统完善版的更多相关文章
- 模拟斗地主和学生管理系统 IO 版
		
1.模拟斗地主 public class PlayCards { public static void main(String[] args) { String[] color = {"黑桃 ...
 - C语言学生管理系统
		
想练习一下链表,所以就有了这个用C写的学生管理系统 没有把它写入文件,才不是因为我懒哈哈哈,主要是为了练习链表的 #include<stdio.h> #include<stdlib. ...
 - C语言学生管理系统(增进版)
		
在原版上进行改进,主要改进的功能有. 1.利用atof:将字符串转换为浮点型: 利用atoi:将字符串转换为整型: 原文地址:http://www.cnblogs.com/sddai/p/577412 ...
 - C语言学生管理系统(C语言课程设计/精简版)
		
#include<stdio.h>#include<stdlib.h>#include<windows.h>#include<conio.h>typed ...
 - C语言学生管理系统(原版本)(自编)
		
/*系统特色:(大牛勿笑) *颜色提示 *文字提示 *功能 */ #include <stdio.h> #include <stdlib.h> #include <mat ...
 - C语言学生管理系统源码分享
		
大家好 我就是如假包换的...陈玲 自从运营了C语言程序设计微信公众号 很多粉丝都给我备注 ...奇葩 实在是不敢当 也被人开始叫玲玲姐 我知道 很多人都想看我出境 我本人也有 年多的舞台演讲训练 实 ...
 - Java小例子(学习整理)-----学生管理系统-控制台版
		
1.功能介绍: 首先,这个小案例没有使用数据库,用集合的形式暂时保存数据,做测试! 功能: 增加学生信息 删除学生信息 修改学生信息 查询学生信息: 按照学号(精确查询) 按照姓名(模糊查询) 打 ...
 - Java 简化版学生管理系统(IO版)
		
Student management system 学生管理系统IO版 详细知识点可参考一下几篇文章 常用API Java 之ArrayList集合及应用 Java 之IO流及应用 Compreh ...
 - python开发的学生管理系统
		
python开发的学生管理系统(基础版) #定义一个函数,显示可以使用的功能列表给用户 def showInfo(): print("-"*30) print(" 学生管 ...
 
随机推荐
- EPX-Studio操作多线程的方法
			
procedure TF1167908962.Button1Click(Sender: TObject); begin ThIndex := ; EPXThread1.StartThread; EPX ...
 - Natas34 Writeup(闯关结束!)
			
Natas34: 登录什么都不用做,闯关结束!撒花~~~
 - SpringBoot源码分析(一)@SpringBootApplication解析
			
@SpringBootApplication解析 三层注解 @SpringBootConfiguration @EnableAutoConfiguration @ComponentScan(exclu ...
 - JS中iframe子页面与父页面之间通信
			
iframe子页面与父页面通信根据iframe中src属性是同域链接还是跨域链接,通信方式也不同. 一.同域下父子页面的通信 父页面parent.html <html> <head& ...
 - Postman从入门到入门
			
1.Postman简介 Postman是一个接口测试工具,在做接口测试的时候, Postman相当于一个客户端,可以发送请求到服务器端.Postman分为Chrome插件版本(不再更新维护)和Nati ...
 - 从SqlSessionFactoryBean的引用浅谈spring两种bean模式
			
mybatis是以一个 SqlSessionFactory 的实例为中心的.SqlSessionFactory可以通过SqlSessionFactoryBuilder获得实例.使用mybatis-sp ...
 - 贪心-最大相容区间-Maximum Number of Events That Can Be Attended
			
2020-02-16 16:24:19 问题描述: 问题求解: 看起来就像是sort + 贪心,但是具体如何做呢? 实际上本题是最大相容区间的变种题,在最大相容区间里,我们按照结束时间对interva ...
 - Codeforce219C-Color Stripe
			
E. Color Stripe time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
 - 性能测试工具Jmeter你所不知道的内幕
			
谈到性能测试,大家一定会联想到Jmeter和LoadRunner,这两款工具目前在国内使用的相当广泛,主要原因是Jmeter是开源免费,LoadRunner 11在现网中存在破解版本.商用型性能测试工 ...
 - mysqlbinlog错误:Error in Log_event::read_log_event(): 'read error'
			
环境: mysql 5.6 ; binlog 3.4 ; binlog_format MIXED ; .报错: mysqlbinlog -v --start-position=166084123 m ...