当前位置:首页 » 编程语言 » c语言成绩管理

c语言成绩管理

发布时间: 2022-03-14 10:27:18

c语言 成绩管理程序

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

#define Num_score 6 // 此处为6门的成绩
#define Num_stu 3 // 此处为3个学生 可自己修改个数

#define score_H 90 //用于成绩筛选
#define score_L 60
typedef struct
{
int id; //编号
char name[30]; //姓名
char gender[10]; //性别
float sc[Num_score]; //存储Num_score门课的分数
float sum; //总成绩
} stu;

int main()
{
stu s[Num_stu];
int i,j;
for(i = 0; i < Num_stu; i++)
{
printf("请输入学生学号\n");
scanf("%d", &s[i].id);
printf("请输入姓名\n");
scanf("%s",s[i].name);
printf("请输入性别\n");
scanf("%s",s[i].gender);
printf("请输入%d门课的成绩\n",Num_score);
for(j = 0; j < Num_score; j++)
scanf("%f",&s[i].sc[j]);
s[i].sum = 0; //计算成绩总和;
for(int k = 0 ; k < Num_score; k++)
s[i].sum = s[i].sum + s[i].sc[k];
// s[i].ave = s[i].sum / Num_score; //平均成绩
}
for(i = 0; i < Num_stu; i++)
{
printf("学号%d的同学%s(%s)的总分为:%.2f \n",s[i].id, s[i].name,s[i].gender,s[i].sum);
for (j = 0; j < Num_score; j++)
{
printf("第%d门成绩为:%.2f \n", j + 1, s[i].sc[j]);
}
}
//按总成绩升序排列
stu stu_temp;
for (i = 1; i < Num_stu; i++)
{
for (j = 0; j < Num_stu - i; j++)
{
if (s[j].sum > s[j + 1].sum)
{
stu_temp = s[j];
s[j] = s[j + 1];
s[j + 1] = stu_temp;
}
}
}
//output
printf("按总成绩排序后:\n");
for(i = 0; i < Num_stu; i++)
{
printf("学号%d的同学%s(%s)的总分为:%.2f \n",s[i].id, s[i].name,s[i].gender,s[i].sum);
for (j = 0; j < Num_score; j++)
{
printf("第%d门成绩为:%.2f \n", j + 1, s[i].sc[j]);
}
}

// 成绩查询
int sid;
printf("请输入学号进行查询:\n");
scanf("%d",&sid);

int flag = 0;
for (i = 0; i < Num_stu; i++)
{
if (sid == s[i].id)
{
flag = 1;
for (j = 0; j < Num_score; j++)
{
printf("%s同学第 %d 门课程成绩为:%.2f \n", s[i].name, j + 1, s[i].sc[j]);
}
printf("该同学的总分为:%.2f \n",s[i].sum);
break;
}
}
if (flag == 0)
{
printf("你输入的信息有误\n");
}

//成绩筛选 >90 || < 60
for (i = 0 ; i < Num_score; i++)
{
printf("第%d门成绩高于%d的同学\n", i + 1, score_H);
for (j = 0; j < Num_stu; j++)
{
if (s[j].sc[i] > score_H)
{
printf("%s %.2f \n", s[j].name, s[j].sc[i]);
}
}
}
for (i = 0; i < Num_score; i++)
{
printf("第%d门成绩低于%d的同学\n", i + 1, score_L);
for (j = 0; j < Num_stu; j++)
{
if (s[j].sc[i] < score_L)
{
printf("%s %.2f \n", s[j].name, s[j].sc[i]);
}
}
}

return 0;
}

⑵ C语言成绩管理系统

给你调试了一下,有些地方已经修改。
#include "stdio.h"
void sort(int m,float x[]);
float max (int m,float y[]);
float min (int m,float z[]);
main()
{
printf("********成绩管理系统********\n");
printf("(可以输入要求管理的学生人数自定)\n");
char string[20];
int i,j,k,a,b;
float math[4],chinese[4],english[4],sum[4],average[4],max1,max2,max3,min1,min2,min3;
for (i=0;i<3;i++)
{
printf("请输入名字");
scanf("%s",string[i+1]); //string没定义
printf("请输入数学成绩");
scanf("%d\n",&math[i+1]);
printf("请输入语文成绩");
scanf("%d\n",&chinese[i+1]);
printf("请输入英语成绩");
scanf("%d\n",&english[i+1]);
sum[i+1]=math[i+1]+chinese[i+1]+english[i+1]; //不同类型
average[i+1]=sum[i+1]/3;
}
printf("各科的最高分与最低分");
printf("数学 语文 英语");
sort(3,sum);
max1=max(3,math);
printf("%d\t",max1);
max2=max(3,chinese);
printf("%d\t",max2);
max3=max(3,english);
printf("%d\n",max3);
min1=min(3,math);
printf("%d\t",min1);
min2=min(3,chinese);
printf("%d\t",min2);
min3=min(3,english);
printf("%d\n",min3);
printf("输出各科平均分");
for (a=1;a<=3;a++)
printf("%f\t",average[a]);
printf("\n");
printf("各科总分从大到小排列");
for (b=1;b<=3;b++)
printf("%f\t",sum[a]);
}
void sort(int m ,float x[])
{
int i,j;float t;
for (i=1;i<=m;i++)
if(x[j]<=x[j+1])
{
t=x[j];
x[j]=x[j+1];
x[j+1]=t;
}
}
float max(int m,float y[])
{
int i;float max;
max=y[1];
for (i=1;i<=m;i++)
if(max<y[i+1])
max=y[i+1];
return(max);
}
float min(int m,float z[])
{
int i;float min;
min=z[1];
for (i=1;i<=m;i++)
if(min>z[i+1])
min=z[i+1];
return(min);
}

⑶ C语言成绩管理系统,

你是沈阳工业大学的把

⑷ c语言成绩管理系统

#include<string.h>
#include<stdio.h>
#define N 100 //最多的学生数
#define HEADLINE " 姓名 学号 语文 数学 英语 总分\n" //标题

//function portotype
void Combine(FILE *,FILE*); //合并两个文件
void Order(FILE *); //总分降序排列
void SearchS(char[] );//查找学生信息
void ScanfOneLine(FILE*);
void PrintOneLine(FILE*);
void Total(); //计算一个学生的总分
void PutIntoSZ(FILE*); //将数据放入数组中,便于排序
void PutIntoFile(struct student st[],FILE *); //将数据放回文件
void PrnFile(FILE*);//打印文件内容
void PrintSZ();//打印数组中的数
void sort1();//冒泡排序
void sort2();//选择排序
void sort3();//插入排序
void Search(); //输入名字显示该生基本信息

struct student
{
char sName[8]; //学生姓名
int sNo; //学号
int Chinese_score; //语文成绩
int Math_score; //数学
int English_score; //英语
int itotal;
}ST={"LiMing",20,91,92,92,100},st[N];

int i; //st数组指标
int num; //st数组有效元素的个数

FILE *fp1,*fp2,*fp3,*fp4; //各个文件指针

main(void)
{
fp1=fopen("d:\\1.txt","r+");
fp2=fopen("d:\\2.txt","r+");

fp3=fopen("d:\\3.txt","a+");
if(fp1==NULL||fp2==NULL)
{
printf("cannot open file!");
}
else
{
Combine(fp1,fp2);
PutIntoSZ(fp3);
PrnFile(fp3);

}
fclose(fp1);
fclose(fp2);
fclose(fp3);

return 0;
}

void Combine(FILE* fp1,FILE* fp2)//OK
{

while(!feof(fp1))
{

ScanfOneLine(fp1);
PrintOneLine(fp3);
}
while(!feof(fp2))
{
ScanfOneLine(fp2);
PrintOneLine(fp3);
}
printf("i=%d\n",i);

}

void PutIntoSZ(FILE*fp)
{

fseek(fp,0L,0); // 确保是从文件头开始读的!
i=0;
while(!feof(fp))
{
ScanfOneLine(fp); //将文件中的数先存入结构体数组中,并计算总分
st[i].itotal=(st[i].Chinese_score +st[i].English_score
+st[i].Math_score );
i++; //若有N个学生,I的最后值是N

}
num=i;//记录个数
}

void ScanfOneLine(FILE*fp)//读一行数据并存入结构体数组中
{
fscanf(fp,"%s%d%d%d%d",&st[i].sName ,&st[i].sNo,
&st[i].Chinese_score ,&st[i].Math_score ,&st[i].English_score);

}

void PrintOneLine(FILE *fp)
{
fprintf(fp,"%8s %3d %5d %5d %5d \n",st[i].sName ,st[i].sNo,
st[i].Chinese_score ,st[i].Math_score ,st[i].English_score);

}

//排序
void Order(FILE* fp)
{

if(fp==fp3){
fclose(fp);
fp=fopen("d:\\3.txt","r+");//!以r+的方式打开才可
}

PutIntoSZ(fp); //将fp的值放入数组中以便排序 I的值为N-1

int k=num;
int temp=num;

//冒泡排序法
for(int k1=0;k1<k-1;k1++)
{
for(int j=0;j<num-2;j++)
{

if(st[j].itotal>st[j+1].itotal)
{
ST=st[j];st[j]=st[j+1];st[j+1]=ST;

}

}
num--;
}
num=temp;//保证num的值不变。标示st[] 有效元素个数
int h=0;

fseek(fp,0L,0);
for( ;h<k-1;)
{

fprintf(fp,"%-8s %3d %3d %3d %3d \n",
st[h].sName ,st[h].sNo,
st[h].Chinese_score ,st[h].Math_score ,st[h].English_score);

h++;

}

}

//打印文件
void PrnFile(FILE* fp)
{
if(fp==fp3){
fclose(fp);
fp=fopen("d:\\3.txt","r+");//!以r+的方式打开才可
}
printf(HEADLINE);

while(!feof(fp))
{
printf("%c",fgetc(fp));

}

return;

}
//数组的数放回文件
void PrintSZ()
{
printf("num=%d",num);
int h=0 ;
num++;

printf(HEADLINE);
while(num--)
{

printf("%8s %3d %5d %5d %5d %5d",
st[h].sName ,st[h].sNo,
st[h].Chinese_score ,st[h].Math_score ,st[h].English_score,st[h].itotal);
printf("\n");
h++;

}

}

//冒泡排序
void sort1()
{
int tag=1;
for(int i=0;i<num-1&&tag==1;i++)
{
tag=0;
for(int j=0;j<N-i-1;i++)
{
if(st[j].itotal>st[j+1].itotal)
{
ST=st[j];st[j]=st[j+1];st[j+1]=ST;
tag=1;
}
}

}

}

//选择排序法
void sort2()
{

for(int i=0;i<num-1;i++)
{
for(int j=0;j<num-i-1;j++)
{
if(st[j].itotal>st[j+1].itotal)
{
ST=st[j]; st[j]=st[j+1]; st[j+1]=ST;
}

}

}
}

// 插入排序
void sort3()
{
int j;
for(int i=0;i<num-1;i++)
{
j=i+1;
while(j--)
{
if(st[j].itotal<st[j-1].itotal)
{
ST=st[j]; st[j]=st[j-1]; st[j-1]=ST;
}
}
}

}

void Search()
{
char a[8];
printf("请输入要查找的学生姓名:");
scanf("%s",a);
PutIntoSZ(fp1);
for(int i=0;i<num;i++)
{
if(!strcmp(st[i].sName,a))
{
printf(HEADLINE);
printf("%8s %3d %5d %5d %5d %5d \n",st[i].sName ,st[i].sNo,
st[i].Chinese_score ,st[i].Math_score ,st[i].English_score,st[i].itotal);
return;
}

}
printf("NOT FOUND!");
return;

}

⑸ c语言 成绩管理系统

我有个自己写的成绩管理系统,lz要可以传给你,可能功能和你的不是很一样。

⑹ 成绩管理系统 c语言

学生成绩管理系统代码
#include<stdio.h>
#include<malloc.h>
#include<string.h>
typedef struct Student
{
int no;
char name[10];
float score[3]; //three scores
float average; //average score
struct Student *next;
}Student;
void Initial(Student *p)
{
p=(Student*)malloc(sizeof(Student));//the head of the linklist
p->next=NULL;
}
void Input(Student *p)
{
Student *stu=(Student*)malloc(sizeof(Student));
printf("学号:"); scanf("%d",&stu->no);
printf("姓名:"); scanf("%s",stu->name);
printf("成绩1:"); scanf("%f",&stu->score[0]);
printf("成绩2:"); scanf("%f",&stu->score[1]);
printf("成绩3:"); scanf("%f",&stu->score[2]);
stu->average=(stu->score[0]+stu->score[1]+stu->score[2])/3;
stu->next=NULL;
Student *ps=(Student*)malloc(sizeof(Student));
ps=p;
while(ps->next)
ps=ps->next;
ps->next=stu;
//free(ps);
}
void Output(Student *p)
{
Student *ps=(Student*)malloc(sizeof(Student));
ps=p->next;
printf("学号\t姓名\t成绩1\t成绩2\t成绩3\t平均分\n");
while(ps!=NULL)
{
printf("%d\t",ps->no);
printf("%s\t",ps->name);
printf("%.1f\t",ps->score[0]);
printf("%.1f\t",ps->score[1]);
printf("%.1f\t",ps->score[2]);
printf("%.1f\t\n",ps->average);
ps=ps->next;
}
free(ps);
}
void Find(Student *p)
{
Student *ps=(Student*)malloc(sizeof(Student));
ps=p->next;
char name[10];
printf("输入要查询的学生姓名:");
scanf("%s",name);
while(strcmp(ps->name,name)!=0) //相同时为0
ps=ps->next;

printf("学号\t姓名\t成绩1\t成绩2\t成绩3\t平均分\n");
printf("%d\t",ps->no);
printf("%s\t",ps->name);
printf("%.1f\t",ps->score[0]);
printf("%.1f\t",ps->score[1]);
printf("%.1f\t",ps->score[2]);
printf("%.1f\t\n",ps->average);

}
void swap(Student *p1, Student *p2) //swap two nodes for sorting
{
Student *temp=(Student*)malloc(sizeof(Student));
temp->no=p1->no;
strcpy(temp->name,p1->name);
temp->score[0]=p1->score[0];
temp->score[1]=p1->score[1];
temp->score[2]=p1->score[2];
temp->average=p1->average;

p1->no=p2->no;
strcpy(p1->name,p2->name);
p1->score[0]=p2->score[0];
p1->score[1]=p2->score[1];
p1->score[2]=p2->score[2];
p1->average=p2->average;

p2->no=temp->no;
strcpy(p2->name,temp->name);
p2->score[0]=temp->score[0];
p2->score[1]=temp->score[1];
p2->score[2]=temp->score[2];
p2->average=temp->average;
free(temp);
}
void Sort(Student *p) //sort by average
{
Student *p1=(Student*)malloc(sizeof(Student));
Student *p2=(Student*)malloc(sizeof(Student));
p1=p->next;
while(p1)
{
float avg=p1->average;
p2=p1->next;
while(p2)
{
if( avg< (p2->average))
{
swap(p1,p2);
avg=p2->average;
}
p2=p2->next;
}
p1=p1->next;
}
}
void Insert(Student *p)
{
printf("按平均分高低插入数据!\n");
Student *stu=(Student*)malloc(sizeof(Student));//the data being inserted

printf("学号:"); scanf("%d",&stu->no);
printf("姓名:"); scanf("%s",stu->name);
printf("成绩1:"); scanf("%f",&stu->score[0]);
printf("成绩2:"); scanf("%f",&stu->score[1]);
printf("成绩3:"); scanf("%f",&stu->score[2]);
stu->average=(stu->score[0]+stu->score[1]+stu->score[2])/3;
stu->next=NULL;

Student *p1=(Student*)malloc(sizeof(Student));//temp
p1=p;
while(p1->next && ((p1->next)->average) >(stu->average))
p1=p1->next;
//p1=p1->next;
stu->next=p1->next;
p1->next=stu;
}
void Menu(Student *p)
{
int select;
printf("您好,欢迎使用学生成绩管理系统!\n");
printf("1:输入学生成绩数据\n2:输出全部学生信息\n3:按姓名查找学生记录\n4:按平均成绩进行排序\n5:按平均成绩高低插入数据\n6:退出\n");
scanf("%d",&select);
while(select<=6 && select>0)
{
switch(select)
{
case 1: Input(p);break;
case 2: Output(p);break;
case 3: Find(p); break;
case 4: Sort(p); break;
case 5: Insert(p); break;
case 6: printf("成功退出,欢迎再次使用!\n"); return ; break;
}
printf("1:输入学生成绩数据\n2:输出全部学生信息\n3:按姓名查找学生记录\n4:按平均成绩进行排序\n5:按平均成绩高低插入数据\n6:退出\n");
scanf("%d",&select);
}

}
int main()
{
Student *head=(Student*)malloc(sizeof(Student));
Menu(head);
}

⑺ c语言编程成绩管理

#include <stdio.h> /*标准输入输出库*/
#include <string.h> /*字符串操作库*/
#include <conio.h> /*控制台函数库*/
#include <malloc.h> /*内存分配库*/
#include <process.h> /*进程库*/

#define INITSIZE 100 /*初始化学生记录的条数*/
#define INCSIZE sizeof(student) /*初始化空间不足时,增加存储空间的字节数*/

typedef struct
{
long no; /*学生序号*/
int math; /*数学成绩*/
int program; /*程序设计成绩*/
int amount; /*总分*/
char name[30]; /*学生姓名*/
}student; /*学生结构体*/

int maxsize = INITSIZE; /*初始化记录条数*/
int num =0; /*当前学生记录条数*/
int dbnull = 1; /*数据库是否存在的标志*/

enum /*查询,排序方式,五种*/
{
Num, /*学号方式*/
Name, /*姓名方式*/
Math, /*数学成绩方式*/
Program, /*程序设计成绩方式*/
Amount /*总分方式*/
};

/*以下为所有函数的声明*/
int createset(student **t);
void addnew(student *t);
void deletestu(student *t);
void stuselect(student *t,int mode);
void scoresort(student *t,int mode);
int findno(student *t,int no);
int findmath(student *t,int math);
int findprogram(student *t,int program);
int findamount(student *t,int amount);
int findname(student *t,const char *name);
void display(student *t,int no);
void mathsort(student *t);
void programsort(student *t);
void amountsort(student *t);
void swap(student *t, int i,int j);

/*以下为函数实现*/
int createset(student **t)/*创建数据记录集*/

{
char ask ;

if (num!=0) /*存在学生记录*/
{
printf("Exsist a data base ,recover it?(Y/N)?");
ask =getch(); /*是否覆盖数据库*/
if (ask == 'y'||ask=='Y')
{
free(*t); /*若选择覆盖,则释放现存存储空间,学生记录个数清零*/
num =0;
}
else
{
return 0; /*不选择覆盖,则退出*/
}
}

*t =(student *)malloc(INITSIZE*sizeof(student)); /*分配INITSIZE个学生记录所需空间*/

if (!t)
{
printf("Memory overflow program abort."); /*内存不足,退出程序*/
exit(0);
}

else
{
printf("New database have been created.\n"); /*分配成功,成功创建数据库*/
dbnull = 0; /*数据库存在标志设为0(表示存在)*/
return 1;
}

}

void addnew(student *t) /*向数据库插入学生记录*/
{
student temp;

if (dbnull) /*数据库存在标志不为0,即无数据库,操作失败*/
{
printf("Not exsist database select menu 1 to create database...");
return;
}
if (num+1>maxsize) /*当前记录个数大于初始化记录条数,追加空间*/
{
t =(student *)realloc(t,maxsize+INCSIZE); /*追加一个记录所需空间*/
if (!t) /*内存不足,追加失败*/
{
printf("Memory overflow! program abort.\n");
exit(0);
}
}

printf("Input the student's No. , name, math score and program score that you want to add.\n");

if (scanf("%ld%s%d%d",&(temp.no), /*输入学生数据*/
temp.name,
&(temp.math),
&(temp.program)))
{
if (findno(t,temp.no) == -1) /*查找输入的学号是否与数据库的重复*/
{
t[num].no = temp.no; /*学号不冲突,则把输入的记录存放到数据库末端*/
strcpy(t[num].name,temp.name);

t[num].math = temp.math;
t[num].program = temp.program;

t[num].amount = t[num].math + t[num].program;
num++; /*当前记录数加一*/

printf("Add sucess!\n");
}

else
{
printf("Exsist the student whom NO. is %d,add fail.\n",temp.no);/*输入学号已经存在,添加记录失败*/
}
}

else
{
printf("Data format error,add fail.\n"); /*输入函数出错,表示输入格式错误,添加失败*/
}

}

void deletestu(student *t) /*从数据库删除某条学生记录*/
{

long delno =0;

int index;

int i =0;

if (dbnull)
{
printf("Not exsist database select menu 1 to create database...");
return;
}

printf("Input the student NO. that you want to delete :\n");

scanf("%ld",&delno); /*输入要删除的学生的学号*/

index = findno(t,delno); /*按学号方式查找该学生是否存在*/

if (index != -1) /*该学生存在,则删除他*/
{

for (i = index+1; i<= num; i++) /*数据库记录前移,完成'删除'操作*/
{

t[i-1].no = t[i].no;
strcpy(t[i-1].name,t[i].name);
t[i-1].math = t[i].math;
t[i-1].program = t[i].program;
t[i-1].amount = t[i].amount;

}
num--; /*当前记录数减一*/

printf("Delete success!\n");

}

else
{
printf("The NO. that you input not exsist delete fail\n"); /*无该学号的学生,删除失败*/
}

}

void stuselect(student *t,int mode) /*搜索数据库*/
{
long tempno =0;
char tempname[30];
int tempmath;
int tempprogram;
int tempamount;
int count =0;

if (dbnull)
{
printf("Not exsist database select menu 1 to create database...");
return;
}

switch (mode) /*判断查询方式*/
{
case Num: /*按学号查询*/
printf("Input the student NO. that you want to search.\n");
scanf("%ld",&tempno); /*输入学号*/
tempno =findno(t,tempno); /*查找该学生*/

if ( tempno!= -1 )
{
printf("Search sucess!.\n");/*查询成功,打印之*/
display(t,tempno);
}
else
{
printf("The NO. that you input not exsist search fail.\n"); /*查找失败*/
}
break;
case Name: /*按姓名查询*/
printf("Input the student name that you want to search.:\n");
*tempname ='\0';
scanf("%s",tempname);
count = findname(t,tempname); /*返回查询姓名为name的学生记录个数*/
printf("There are %d student have been searched.\n",count);
break;
case Math: /*按数学成绩查询*/
printf("Input the a score, program will search students which math scores are higher than it.\n");
scanf("%d",&tempmath);
count = findmath(t,tempmath);
printf("There are %d student have been searched.\n",count);
break;

case Program: /*按程序设计成绩查询*/

printf("Input the a score, program will search students which programming scores are higher than it.\n");
scanf("%d",&tempprogram);
count = findprogram(t,tempprogram);
printf("There are %d student have been searched.\n",count);
break;

case Amount: /*按总分查询*/
printf("Input the a score, program will search students which sum scores are higher than it\n");
scanf("%d",&tempamount);
count = findamount(t,tempamount);
printf("There are %d student have been searched.\n",count);
break;
default:
break;

}

}

void scoresort(student *t,int mode) /*学生记录排序*/
{
int count =0;

switch (mode) /*选择不同排序方式进行成绩排序*/
{
case Math:
mathsort(t); /*按数学成绩排序*/
break;
case Program: /*按程序设计成绩排序*/
programsort(t);
break;
case Amount: /*按总分排序*/
amountsort(t);
break;
}

printf("Sorting have been finished .flowing is the result:\n");
for (count =0;count< num; count++) /*排序完成后输出排序结果*/
{
display(t,count);
}
}

int findno(student *t,int no)/*按学号查找学生记录*/
{
int count =0;
for (count =0; count<num; count++)
{
if ((t+count)->no == no) /*逐个搜索,若该学生记录的学号等于需要查找的学号,则返回该学号*/
{
return count;
}
}
return -1; /*搜索完毕,仍没有匹配学号,则返回-1*/
}

int findmath(student *t,int math)
{
int count =0; /*按数学成绩查找,这里查找的结果是大于指定数学分数的所有学生记录*/
int i =0;
for (count =0; count<num; count++)
{
if ((t+count)->math > math)
{
display (t,count); /*显示查找结果*/
i++;
}
}

return i; /*返回符合查询条件的学生记录数目*/
}

int findprogram(student *t,int program)/*按程序设计成绩查找学生记录,算法类似上面的模块*/
{
int count =0;
int i =0;
for (count =0; count<num; count++)
{
if ((t+count)->program > program)
{
display(t,count);
i++;
}
}

return i;
}

int findamount(student *t,int amount)/*类似上面的模块*/
{
int count =0;
int i =0;
for (count =0; count<num; count++)
{
if ((t+count)->amount > amount)
{
display(t,count);
i++;
}
}

return i;
}

int findname(student *t,const char *name) /*类似上面的模块*/
{
int count =0;
int i =0;
for (count =0; count<num; count++)
{
if (!strcmp((t+count)->name,name))
{
display(t,count);
i++;
}
}

return i;
}

void display(student *t,int no) /*打印指定学生记录*/
{
printf("NO.: %2ld Name:%10s Math : %2d Programing: %2d Sum: %3d .\n",
t[no].no,
t[no].name,
t[no].math,
t[no].program,
t[no].amount);
}

void mathsort(student *t) /*数学成绩排序,使用选择排序算法*/
{

int i;
int j;

for ( i =0; i< num-1; i++)
for ( j =i+1; j<num; j++)
{
if ( t[j].math > t[i].math )
{
swap(t,j,i);
}
}
}

void programsort(student *t) /*类似数学成绩排序*/
{

int i;
int j;

for ( i =0; i< num-1; i++)
for ( j =i+1; j<num; j++)
{
if ( t[j].program > t[i].program )
{
swap(t,j,i);
}
}
}

void amountsort(student *t) /*类似数学成绩排序*/
{

int i;
int j;

for ( i =0; i< num-1; i++)
for ( j =i+1; j<num; j++)
{
if ( t[j].amount > t[i].amount )
{
swap(t,j,i);
}
}
}

void swap(student *t, int i,int j) /*交换两个学生的记录内容*/
{
student temp; /*定义一个中间记录*/

temp.no = t[j].no; /*逐个交换记录的数据项*/
t[j].no = t[i].no;
t[i].no = temp.no;

strcpy(temp.name , t[j].name);
strcpy(t[j].name , t[i].name);
strcpy(t[i].name , temp.name);

temp.math = t[j].math;
t[j].math = t[i].math;
t[i].math = temp.math;

temp.program = t[j].program;
t[j].program = t[i].program;
t[i].program = temp.program;

temp.amount = t[j].amount;
t[j].amount = t[i].amount;
t[i].amount = temp.amount;
}

void main() /*Main mole 主控模块*/
{

student *t; /*定义整个程序学生记录数据块,用指针t标识*/

int Menu =0,submenu =0;/*表示菜单项,主菜单,子菜单*/

printf("\n\t\t********Students information manage system.********\n");
while ( Menu!= '6' ) /*选择菜单若为'6':(退出项),则退出菜单选择*/
{

fflush(stdin); /*清除输入缓冲区*/
submenu =0; /*重置子菜单的选中项*/
printf("\
\n\
1>.New database.\n\
2>.Add data record.\n\
3>.Delete data record.\n\
4>.Sort.\n\
5>.Search.\n\
6>.Exit\n");

printf("\nInput the menu's command...\n");
Menu = getchar(); /*选择菜单*/

switch (Menu) /*按选择的菜单项,执行相应模块*/
{
case '1':
createset(&t);
break;
case '2':
addnew(t);
break;
case '3':
deletestu(t);
break;
case '4':
if (dbnull) /*数据库不存在,不予以处理*/
{
printf("Not exsist database select menu 1 to create database...");
break;
}

while (submenu != '4' )/*进入排序方式的子菜单*/
{
fflush(stdin);
printf("\t****Score sort****\n\
1>.Math score sort.\n\
2>.Programming score sort.\n\
3>.Sum score sort.\n\
4>.Return to main menu.\n");
printf("\n\tInput the menu's command...\n");
submenu = getchar();

switch ( submenu )
{

case '1':
scoresort(t,Math);
break;
case '2':
scoresort(t,Program);
break;
case '3':
scoresort(t,Amount);
break;
case '4':
break;
default:
break;
}

}
break;
case '5':

if (dbnull)
{
printf("Not exsist database select menu 1 to create database...");
break;
}
while (submenu != '6') /*进入查询子菜单*/
{
fflush(stdin);

printf("\t****Student search.*****\n\
1>NO. search.\n\
2>Name search.\n\
3>Math score search.\n\
4>Programming score search.\n\
5>Sum score search.\n\
6>Return to main menu.\n");

printf("\n\tInput the menu command...\n");
submenu = getchar();

switch (submenu)
{
case '1':
stuselect(t,Num);
break;
case '2':
stuselect(t,Name);
break;
case '3':
stuselect(t,Math);
break;
case '4':
stuselect(t,Program);
break;
case '5':
stuselect(t,Amount);
break;
case '6':
break;
default:
break;
}

}

case '6':
break;
default:
break;
}

}

printf("End ************Student information manage system*****\n");

printf("\t\t\t\t\t\tPress any key to exit...");
fflush(stdin);
getch(); /*按任意键返回*/
}

⑻ c语言学生成绩管理系统

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

#define MAX 80 //学生最大人数

#define max 3 //科目数量

struct classname //科目结构体,科目名称,该科目分数
{
char name[20];
float score;
};

struct student //学生结构体,学号,学生姓名,科目,平均分,总分
{
char no[20];
char std_name[20];
struct classname km[max];
float ave;
float sum;
int save; //检验数,没有添加删除函数,此变量没有作用,可删除,但是注意删除要把初始函数里的初始语句也删除
};

struct student stu[MAX];//全局变量,结构体数组

int nu=0;//全局变量 文件已存人数

void chushi()//程序初始化函数,对全局变量stu初始化
{
int i,j;
for(i=0;i<MAX;i++)
{
for(j=0;j<20;j++)
{
stu[i].no[j]='\0';
stu[i].std_name[j]='\0';
stu[i].km[j].name[j]='\0';
stu[i].km[j].score=0;
}
stu[i].ave=0;
stu[i].sum=0;
stu[i].save=0;
}
}

void av()/*求平均值*/
{
int i;
for(i=0;i<nu;i++)
{
stu[i].sum=stu[i].km[0].score+stu[i].km[1].score+stu[i].km[2].score;
stu[i].ave=stu[i].sum/3;
}
}

void first_check()
{
FILE *p;//文件指针
int i,j;
struct classname frist[max];//临时变量,接收第一次输入的科目名称
for(i=0;i<max;i++)
{
for(j=0;j<20;j++)
frist[i].name[j]='\0';
frist[i].score=0;
}
if ((p=fopen("e:\\kemu.txt","r"))==NULL)//如果文件不存在,执行下面语句
{
printf("您好,欢迎使用学生成绩管理系统\n\n因为您是第一次使用,请输入科目名称(三科)\n\n");
p=fopen("e:\\kemu.txt","w");//建立科目文件,保存c盘根目录
printf("输入课程1名称:");
scanf("%s",frist[0].name);
fprintf(p,"%s\n",frist[0].name);//课程写入文件
printf("输入课程2名称:");
scanf("%s",frist[1].name);
fprintf(p,"%s\n",frist[1].name);//同上
printf("输入课程3名称:");
scanf("%s",frist[2].name);
fprintf(p,"%s\n",frist[2].name);//同上
}
system("cls");//清屏函数
fclose(p);
}

void save_nu()//往人数文件写入人数信息
{
FILE *p;
p=fopen("e:\\renshu.txt","w");
fprintf(p,"%d\n",nu);
fclose(p);
}

void Save_add(int n)//写入成绩信息,成绩文件已存在,在文件内部末尾追加写入
{
FILE * p;
int i;
p= fopen("e:\\chengji.txt","at");
if (p == NULL)
{
printf("文件不存在!!\n");
exit(0);
}
save_nu();
for (i = 0;i<n;i++)
if(stu[i].save==1)
{
stu[i].sum=stu[i].km[1].score+stu[i].km[2].score+stu[i].km[3].score;
stu[i].ave=stu[i].sum/3;
fprintf(p,"%s %s %2.1f %2.1f %2.1f %2.1f %2.1f \n",stu[i].no,stu[i].std_name,stu[i].km[0].score,stu[i].km[1].score,stu[i].km[2].score,stu[i].ave,stu[i].sum);
}
fclose(p);
}

void Save()//写入成绩信息,成绩文件不存在,新建成绩文件并写入信息
{
FILE * p;
int i;
p= fopen("e:\\chengji.txt","w");
if (p == NULL)
{
printf("文件不存在!!\n");
exit(0);
}
save_nu();
for (i = 0;i<nu;i++)
if(stu[i].save==1)
{
av();
fprintf(p,"%s %s %2.1f %2.1f %2.1f %2.1f %2.1f \n",stu[i].no,stu[i].std_name,stu[i].km[0].score,stu[i].km[1].score,stu[i].km[2].score,stu[i].ave,stu[i].sum);
}
fclose(p);
}

int read_nu()//读取人数文件中存在的人数信息
{
FILE *p;
char ch,s[10]={'\0'};
int i=0;
p=fopen("e:\\renshu.txt","r");
if(p==NULL)
{
save_nu();
return 0;
}
ch=fgetc(p);
while(ch!='\n')
{
s[i]=ch;
ch=fgetc(p);
i++;
}
nu=atoi(s);
fclose(p);
return 0;
}

int read_km()//读取科目文件中存储的科目信息
{
FILE *p;
int i,j=0;
char s[20]={'\0'};
chushi();
p=fopen("e:\\kemu.txt","r");
if(p==NULL)
{
printf("ERROR read_km");
return 0;
}
fgets(s,20,p);
while(strlen(s)!=0)
{
for(i=0;i<strlen(s);i++)
if(s[i]==10)
{
s[i]='\0';
break;
}
for(i=0;i<=nu;i++)
strcpy(stu[i].km[j].name,s);
for(i=0;i<20;i++)
s[i]='\0';
j++;
fgets(s,20,p);
}
return 0;
}

void read()//重要函数!读取成绩文件中以存储的学生成绩信息并存入内存
{
FILE *p;
int i,j,n,k,z=0;
char s[50]={'\0'};
char o[10]={'\0'};
p=fopen("e:\\chengji.txt","r");
if(p==NULL)
printf("ERROR_read");
chushi();
read_km();
fgets(s,50,p);
while(strlen(s)!=0)
{
j=0;
for(i=0;i<50;i++)
{
if(s[i]!='\n')
{
n=0;
while(j==0)
{
if(s[i]!=' ')
{
stu[z].no[n]=s[i];
n++;i++;
}
else
break;
}
while(j==1)
{
if(s[i]!=' ')
{
stu[z].std_name[n]=s[i];
n++;i++;
}
else
break;
}
while(j==2)
{
if(s[i]!=' ')
{
o[n]=s[i];
n++;i++;
}
else
{
stu[z].km[0].score=atoi(o);
break;
}
}
while(j==3)
{
if(s[i]!=' ')
{
o[n]=s[i];
n++;i++;
}
else
{
stu[z].km[1].score=atoi(o);
break;
}
}
while(j==4)
{
if(s[i]!=' ')
{
o[n]=s[i];
n++;i++;
}
else
{
stu[z].km[2].score=atoi(o);
break;
}
}
while(j==5)
{
if(s[i]!=' ')
{
o[n]=s[i];
n++;i++;
}
else
{
stu[z].ave=atoi(o);
break;
}
}
while(j==6)
{
if(s[i]!=' ')
{
o[n]=s[i];
n++;i++;
}
else
{
stu[z].sum=atoi(o);
break;
}
}
for(k=0;k<10;k++)
o[k]='\0';
}
else
break;
j++;
}
for(i=0;i<50;i++)
s[i]='\0';
fgets(s,50,p);
z++;
}
}

void putin()//功能函数,录入学生成绩信息
{
int n,i=0;
char ch;
read_km();
do
{
printf("\t\t\t\t录入学生信息\n输入第%d个学生的信息\n",i+1);
printf("\n输入学生学号:");
scanf("%s",stu[i].no);
printf("\n输入学员姓名:");
scanf("%s",stu[i].std_name);
printf("\n输入语文%s的分数:",stu[0].km[0].name);
scanf("%f",&stu[i].km[0].score);
printf("\n输入数学%s的分数:",stu[0].km[1].name);
scanf("%f",&stu[i].km[1].score);
printf("\n输入英语%s的分数:",stu[0].km[2].name);
scanf("%f",&stu[i].km[2].score);
stu[i].save=1;
printf("\n\n");
i++;
n=i;
printf("是否继续输入?(Y/N)");
fflush(stdin);
ch=getch();
system("cls");
}
while(ch!='n'&&ch!='N');
system("cls");
if(nu==0)
{
nu=n;
Save();
}
else
{
nu=n+nu;
Save_add(n);
}
}

int putout()//功能函数,显示学生信息
{
int i;char s;
if(nu==0)
{
printf("学生信息为零!请录入...");
return 0;
}
read();
do
{
printf("学生成绩信息:\n\n");
for(i=0;i<nu;i++)
printf("学号:%s 姓名:%s\n%s分数:%2.1f\t%s分数:%2.1f\t%s 分数:%2.1f\n平均分数:%2.1f\t总成绩:%2.1f\n\n",stu[i].no,stu[i].std_name,stu[i].km[0].name,stu[i].km[0].score,stu[i].km[1].name,stu[i].km[1].score,stu[i].km[2].name,stu[i].km[2].score,stu[i].ave,stu[i].sum);
printf("\t\t按任意键返回主菜单");
fflush(stdin);
s=getch();
}
while(!s);
system("cls");
return 0;
}

int sort()/*排序数据函数*/
{
struct student temp;
int i,j;
char s;
if(nu==0)
{
printf("学生信息为零!请录入...");
return 0;
}
read();
for(i=1;i<nu;i++)
{
for(j=1;j<=nu-i;j++)
{
if(stu[j-1].ave<stu[j].ave)
{
temp=stu[j];
stu[j]=stu[j-1];
stu[j-1]=temp;
}
}
}
do
{
printf("学生成绩信息:\n\n");
for(i=0;i<nu;i++)
printf("学号:%s 姓名:%s 平均成绩:%2.1f\n\n",stu[i].no,stu[i].std_name,stu[i].ave);
printf("\t\t按任意键返回主菜单");
fflush(stdin);
s=getch();
}
while(!s);
system("cls");
return 0;
}

int find()/*查询函数*/
{
int j,i=0;
int c=0;
char search[20]={'\0'};
char as;
if(nu==0)
{
printf("学生信息为零!请录入...");
return 0;
}
read();
do
{
printf("输入要查询课程名称:");
scanf("%s",search);
for(j=0;j<max;j++)
if(!strcmp(stu[i].km[j].name,search))
{
c=1;
printf("\n该课程不及格学生姓名:\n");
for(i=0;i<nu;i++)
if(stu[i].km[j].score<60)
printf("%s\n",stu[i].std_name);
}
if(c==0)
printf("无此课程!");
printf("\n\t\t按任意键返回主菜单");
fflush(stdin);
as=getch();
}
while(!as);
system("cls");
return 0;
}

int tongji()//功能函数,统计学生成绩信息
{
int j,m,z,i=0;
char s;
if(nu==0)
{
printf("学生信息为零!请录入...");
return 0;
}
read();
for(z=0;z<max;z++)
{
m=stu[i].km[z].score;j=0;
printf("%s 最高分: ",stu[i].km[z].name);
for(i=0;i<nu;i++)
if(m<stu[i].km[z].score)
{
m=stu[i].km[z].score;
j=i;
}
printf("%s\t",stu[j].std_name);
j=0;i=0;m=stu[i].km[z].score;
printf("%s 最低分: ",stu[i].km[z].name);
for(i=0;i<nu;i++)
if(m>stu[i].km[z].score)
{
m=stu[i].km[z].score;
j=i;
}
printf("%s\t",stu[j].std_name);
m=0;j=0;i=0;
printf("%s 平均分: ",stu[i].km[z].name);
for(i=0;i<nu;i++)
m=m+stu[i].km[z].score;
printf("%d\n",m/nu);
m=0;i=0;
printf("%s 分数低于的60人数: ",stu[i].km[z].name);
for(i=0;i<nu;i++)
if(stu[i].km[z].score<60)
m++;
printf("%d\t",m);
m=0;j=0;i=0;
printf("%s 分数高于60的人数: ",stu[i].km[z].name);
for(i=0;i<nu;i++)
if(stu[i].km[z].score>60)
m++;
printf("%d\n\n",m);
}
do
{
printf("\t\t按任意键返回主菜单");
fflush(stdin);
s=getch();
}
while(!s);
system("cls");
return 0;
}

void main()/*主函数*/
{
int as;
first_check();
start: printf("\n\t\t\t欢迎使用学生成绩管理系统\n");
/*一下为功能选择模块*/
do
{
printf("\n\t\t\t\t1.录入学生信息\n\t\t\t\t2.显示学生信息\n\t\t\t\t3.成绩排序信息\n\t\t\t\t4.查询不及格学生\n\t\t\t\t5.统计信息\n\t\t\t\t6.退出\n");
printf("\t\t\t\t选择功能选项:");
fflush(stdin);
read_nu();
scanf("%d",&as);
switch(as)
{
case 1:system("cls");putin();break;
case 2:system("cls");putout();break;
case 3:system("cls");sort();break;
case 4:system("cls");find();break;
case 5:system("cls");tongji();break;
case 6:system("exit");exit(0);
default:system("cls");goto start;
}
}
while(1);
/*至此功能选择结束*/
}

⑼ C语言学生成绩管理系统

要dos窗口的吗?

⑽ c语言 学生成绩管理程序

晕,这在一般课程设计的书里都能找到相似的...自己写一次吧,对你编程有很大帮助的.

热点内容
脚本玩具 发布:2025-07-21 18:34:54 浏览:347
安卓10交互模式是什么 发布:2025-07-21 18:30:46 浏览:994
存储几层 发布:2025-07-21 18:20:18 浏览:262
安卓手机相册是哪个 发布:2025-07-21 18:15:13 浏览:542
c语言的fork函数 发布:2025-07-21 17:50:05 浏览:745
怎么给文件夹改名字叫什么 发布:2025-07-21 17:37:22 浏览:893
php发包 发布:2025-07-21 17:36:47 浏览:4
怎么配置mc服务器 发布:2025-07-21 17:35:37 浏览:998
androidjson接收 发布:2025-07-21 17:29:12 浏览:62
苹果手机短信加密 发布:2025-07-21 17:23:18 浏览:462