TOP

期末成绩管理系统(一)
2019-08-15 23:30:43 】 浏览:115
Tags:期末 成绩 管理系统

#include"stdio.h"

#include"string.h"

#include"conio.h"

#include"math.h"

#define SIZE 300

typedef struct student

{

int number;

int score[3];

} STUDENT;

typedef enum boolen

{False,True

}FLAG;

int accept_data(STUDENT stu[],int grade[]);

void show_data(STUDENT stu[],int sum,int grade[]);

void draw(int grade[]);

void count(int *max,int *min,double *pass,double ave[],double f[],STUDENT stu[],int sum);

void show_data2(int max,int min,double pass,double ave[],double f[]);

int main()

{int sum,max,min;

double pass=0;

int grade[11]={0};

STUDENT stu[SIZE];

double ave[SIZE],f[SIZE];

sum=accept_data(stu,grade);

show_data(stu,sum,grade);

draw(grade);

count(&max,&min,&pass,ave,f,stu,sum);

show_data2(max,min,pass,ave,f);

return 0;

}

int accept_data(STUDENT stu[],int grade[])

{int i=0,sum=0,temp,a1,a2;

FLAG flag;

printf("\n请输入计算总评成绩时使用平时成绩与期末成绩的比例,用整数表示");

scanf("%d%d",&a1,&a2);

while(i<>

{printf("\n请输入学号:");

scanf("%d",&stu[i].number);

if(stu[i].number==-1)

{sum=i;

break;

}

printf("\n请输入学生的平时成绩和期末成绩:");

flag=True;

while(flag==True)

{scanf("%d%d",&stu[i].score[0],&stu[i].score[1]);

if(stu[i].score[0]<=100&&stu[i].score[0]>=0&&stu[i].score[1]<=100&&stu[i].score[1]>=0)

flag=False;

else

printf("\n\007 错误数据!请再次输入学生的平时成绩和期末成绩:"); 

}

temp=(int)(1.0*a1/100*stu[i].score[0]+1.0*a2/100*stu[i].score[1]);

stu[i].score[2]=temp;

temp=(stu[i].score[1])/10;

if(temp==10)

grade[10]++;

else grade[temp+1]++;

i++;

}

return sum;

}

void show_data(STUDENT stu[],int sum,int grade[])

{

int i,j;

for(i=0;i<>

{printf("%4d",stu[i].number);

for(j=0;j<3;j++)

printf("%4d",stu[i].score[j]);

printf("\n");

}

for(i=1;i<=10;i++)

printf("%d",grade[i]);

}

void count(int *max,int *min,double *pass,double ave[],double f[],STUDENT stu[],int sum)

{int i,j,p_sum=0;

int total[3];

double temp;

*max=*min=stu[0].score[1];

if(stu[0].score[1]>=60)

p_sum++;

for(i=1;i<>

{if((stu[i].score[1])>*max)

*max=stu[i].score[1];

if((stu[i].score[1])<*min)

*min=stu[i].score[1];

if(stu[i].score[1]>=60)

p_sum++;

}

*pass=(1.0*p_sum/sum)*100;

for(i=0;i<=2;i++)

total[i]=0;

for(j=0;j<3;j++)

for(i=0;i<>

{

total[j]=total[j]+stu[i].score[j];

}

for(j=0;i<3;j++)

{ave[j]=total[j]/sum;

}

for(j=0;j<3;j++)

{

f[j]=0;

for(i=0;i<>

{

temp=stu[i].score[j]-ave[j];

f[j]=f[j]+temp*temp;

}

f[j]=sqrt(fabs(f[j])/sum);

}

}

void show_data2(int max,int min,double pass,double ave[],double f[])

{

int j;

char str1[3][20]={"平时成绩平均分","期末成绩平均分","总评成绩平均分"};

char str2[3][20]={"平时成绩标准差","期末成绩标准差","总评成绩平标准差"};

printf("\n 及格率=%6.2f%%最高分=%d最低分=%d\n",pass,max,min);

for(j=0;j<3;j++)

printf("\n %s=%6.2f%s=%6.2f\n",str1[j],ave[j],str2[j],f[j]);

}

void draw(int grade[])

   {

   int i,j,max,k,temp,x;

char screen[22][44];

printf("\n 模拟直方图\n");

max
期末成绩管理系统(一) https://www.cppentry.com/bencandy.php?fid=88&id=229534

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Linux(centOS6.5)安装RabbitMQ 下一篇java线程锁基础

kafka-
kafka   Partit
解决android studio
Kafka史上最详细原理
Error while fetchin
【Kafka】安装与快速
    &
flume读取日志数据写
Authentication plug
Flume 自定义source
flume   三大核
ICC副本>>>
愚公移山  
Hbase架构   Hb
5 hbase-shell + &
Hbase   MapRed
MetaException(messa
Exception in thread
HIVE metastore Dupl
-->