c 语言编写的学生成绩管理系统

作者&投稿:何昌 (若有异议请与网页底部的电邮联系)
用C语言编程实现一个简单的学生成绩管理系统~

#include #include #include #includetypedef struct student{char num[16];char name[20];float score[4];struct student *next;} stu;stu *head; // 链头指针stu* create()// 创建链表,从文件读取信息 { printf("Reading student information:
");stu *p=NULL;// 指针,指向个待插入的结点stu *q=NULL;// 指针,用于在其后插入结点head = NULL;// 一开始链表为空FILE * r =fopen("input.dat","r"); p = (stu*)malloc(sizeof(stu));while(fscanf(r,"%s%s%f%f%f",p->num,p->name,&p->score[0],&p->score[1],&p->score[2])!=EOF){ p->score[3]=(p->score[0]+p->score[1]+p->score[2])/3.0; fprintf(stdout,"%s%s%g%g%g%.2f
",p->num,p->name,p->score[0],p->score[1],p->score[2],p->score[3]); p->next=NULL;if (head == NULL)// head为空,要插入第一个 { head = p; } // 结点,让头指针指向结点pelse {// 否则不是头结点,应将p结点q->next = p;// 插入到q结点的后面} q = p;// q指向当前最后一个结点 p = (stu*)malloc(sizeof(stu));} fclose(r);if (head != NULL) { q->next = NULL;// 让q所指的最后一个结点的指针域为空说明这已是链尾了} return head;// 返回头指针} void sort(stu **head,int n) { FILE *w=NULL; if(n==0) { w = fopen("sortByMath.dat","w"); } else if(n==1) { w = fopen("sortByEnglish.dat","w"); } else if(n==2) { w = fopen("sortByComputer.dat","w"); } else if(n==3) { w = fopen("sortByAvg.dat","w"); } stu *q,*t,*p; stu * new_head = new stu; new_head->next=*head; p=new_head; t=NULL; while(t!=new_head->next) { p=new_head; q=p->next; while(q->next!=t) { if((p->next->score[n]) next->score[n])) { p->next=q->next; q->next=q->next->next; p->next->next=q; } p=p->next; q=p->next; } t=q; } *head = new_head->next; p = *head; q = p->next; printf("学号姓名数学英语计算机平均成绩
"); int grade = 1; while(p!=NULL) { fprintf(w,"%s%s%g%g%g%.2f%d
", p->num,p->name,p->score[0],p->score[1],p->score[2],p->score[3],grade); fprintf(stdout,"%s%s%g%g%g%.2f%d
", p->num,p->name,p->score[0],p->score[1],p->score[2],p->score[3],grade); if(q!=NULL && q->score[3] score[3]) grade += 1; p=p->next; if(q!=NULL) q=q->next; } printf("
"); fclose(w);} void count(stu* head){ float cnt[4][8]; int i,j; for(i=0;inext; }}int main( ) { head=create(); printf("Sorting by average score:
"); sort(&head,3); system("pause"); return 0;}

以下是我做过的成品#include "stdio.h"#include "stdlib.h"#include "string.h"#define N 100 //最大学生数量#define LEN sizeof(struct student)FILE *fp;int n=0; //学生数量struct student{int num;char name[20];int x_num;int class_num;float score1;float score2;float score3;float total;float average;}stu[N]; //学生信息结构体/*1.学生信息存入文件*/void creat() {int i,j;struct student t;printf("输入学生的数量。(不超过%d)
",N);scanf("%d",&n);if(n>N) exit(0);printf("依次输入学生信息:学号 姓名 学院代号 班级号 高数成绩 英语成绩 C语言成绩
");for(i=0;i stu[i+1].num){t=stu[i];stu[i]=stu[i+1];stu[i+1]=t;}}if((fp=fopen("student_number","wb"))==NULL) //保存学生数量n{printf("can't open file!
");exit(0);}fwrite(&n,sizeof(int),1,fp);if((fp=fopen("student","wb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;istu[n-1].num){n=n+1;stu[n-1]=t;}elsefor(i=0;ii-1;j--) stu[j+1]=stu[j];stu[i]=t;break;}}if((fp=fopen("student_number","wb"))==NULL){printf("can't open file!
");exit(0);}fwrite(&n,sizeof(n),1,fp);if((fp=fopen("student","wb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++)fwrite(&stu[i],LEN,1,fp);fclose(fp);begin:printf("@是否继续“添加”操作(y/n)?
");fflush(stdin);ch=getchar();if(ch=='y'||ch=='Y') add();else if(ch=='n'||ch=='N') ;else { printf("输入有误!
"); goto begin;}}/*3.删除学生信息*/void del() {int i,numb,mark=0;char ch;printf("输入要删除学生的学号:
");scanf("%d",&numb);if((fp=fopen("student_number","rb"))==NULL){printf("can't open file!
");exit(0);}fread(&n,sizeof(n),1,fp);if((fp=fopen("student","rb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++){fread(&stu[i],LEN,1,fp);if(stu[i].num==numb){i--;n--;mark=1;}}if(mark==0) printf("没有该生信息
");if((fp=fopen("student_number","wb"))==NULL){printf("can't open file!
");exit(0);}fwrite(&n,sizeof(n),1,fp);if((fp=fopen("student","wb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++)fwrite(&stu[i],LEN,1,fp);fclose(fp);begin:printf("@是否继续“删除”操作(y/n)?
");fflush(stdin);ch=getchar();if(ch=='y'||ch=='Y') del();else if(ch=='n'||ch=='N') ;else { printf("输入有误!
"); goto begin;}}/*4.修改学生信息*/void change() {int i,numb,mark=0;float score1,score2,score3,totall,average;char ch;printf("输入要修改学生的学号 高数成绩 英语成绩 C语言成绩:
");scanf("%d %f %f %f",&numb,&score1,&score2,&score3);if((fp=fopen("student_number","rb"))==NULL){printf("can't open file!
");exit(0);}fread(&n,sizeof(n),1,fp);if((fp=fopen("student","rb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++){fread(&stu[i],LEN,1,fp);if(stu[i].num==numb){totall=score1+score2+score3;average=totall/3;stu[i].score1=score1;stu[i].score2=score2;stu[i].score3=score3;stu[i].total=totall;stu[i].average=average;mark=1;}}if(mark==0) printf("没有该生信息
");if((fp=fopen("student_number","wb"))==NULL){printf("can't open file!
");exit(0);}fwrite(&n,sizeof(n),1,fp);if((fp=fopen("student","wb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++)fwrite(&stu[i],LEN,1,fp);fclose(fp);begin:printf("@是否继续“修改”操作(y/n)?
");fflush(stdin);ch=getchar();if(ch=='y'||ch=='Y') del();else if(ch=='n'||ch=='N') ;else { printf("输入有误!
"); goto begin;}}/*5.查询操作*///(1)按学号查询,输入一个学号,输出对应的学生信息。void num_search() {int i,num,mark=0;printf("输入学号:
");scanf("%d",&num);for(i=0;i<n;i++)if(stu[i].num==num){printf("学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2哗笭糕蝗蕹豪革通宫坤f
",stu[i].num,stu[i].name,stu[i].x_num,stu[i].class_num,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].total,stu[i].average);mark=1;}if(mark==0) printf("没有找到相关信息。
");}//(2)按全名查询。void name_search(){int i,mark=0;char name[20];printf("输入姓名:
");scanf("%s",name);for(i=0;i<n;i++)if(strcmp(stu[i].name,name)==0){printf("学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[i].num,stu[i].name,stu[i].x_num,stu[i].class_num,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].total,stu[i].average);mark=1;}if(mark==0) printf("没有找到相关信息。
");}//(3)按姓氏查询。void firstname_search(){int i,mark=0;char name[20];printf("输入姓氏:
");scanf("%s",name);for(i=0;i<n;i++)if(stu[i].name[0]==name[0] && stu[i].name[1]==name[1]){printf("学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[i].num,stu[i].name,stu[i].x_num,stu[i].class_num,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].total,stu[i].average);mark=1;}if(mark==0) printf("没有找到相关信息。
");}//(4)按学院查询,输入学院名称,输出该学院的全部学生的信息。void x_search(){int i,x_num,mark=0;printf("输入学院代号:
");scanf("%d",&x_num);for(i=0;i<n;i++)if(stu[i].x_num==x_num){printf("学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[i].num,stu[i].name,stu[i].x_num,stu[i].class_num,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].total,stu[i].average);mark=1;}if(mark==0) printf("没有找到相关信息。
");}//(5)按班级查询,输入班级名称,输出该班级的全部学生的信息。void classnum_search(){int i,class_num,mark=0;printf("输入学院代号:
");scanf("%d",&class_num);for(i=0;i<n;i++)if(stu[i].class_num==class_num){printf("学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[i].num,stu[i].name,stu[i].x_num,stu[i].class_num,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].total,stu[i].average);mark=1;}if(mark==0) printf("没有找到相关信息。
");}//查询模块void search() {char ch;int i;if((fp=fopen("student_number","rb"))==NULL){printf("can't open file!
");exit(0);}fread(&n,sizeof(n),1,fp);if((fp=fopen("student","rb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++)fread(&stu[i],LEN,1,fp);fclose(fp);printf("选择要进行查询的关键字代号:1、学号查询。2、按全名查询。3、按姓氏查询。4、学院查询。5、班级查询。
");fflush(stdin);ch=getchar();switch(ch){case '1': num_search(); break;case '2': name_search(); break;case '3': firstname_search(); break;case '4': x_search(); break;case '5': classnum_search(); break;default :printf("输入代号有误。
");}begin:printf("@是否继续“查询”操作(y/n)?
");fflush(stdin);ch=getchar();if(ch=='y'||ch=='Y') search();else if(ch=='n'||ch=='N') ;else { printf("输入有误!
"); goto begin;}}/*6.统计*///(1)按总分对学生信息进行排序(由高到低),输出排序后的信息,并将排序后的学生信息存放到一个新的二进制文件中。void totall_score(){int i,j;struct student t;for(j=0;j<n-1;j++)for(i=0;i<n-j-1;i++)if(stu[i].total<stu[i+1].total){t=stu[i];stu[i]=stu[i+1];stu[i+1]=t;}if((fp=fopen("student_number","wb"))==NULL){printf("can't open file!
");exit(0);}fwrite(&n,sizeof(n),1,fp);if((fp=fopen("student_totalscore","wb"))==NULL) //按总分排序并保存至新的文件夹中。{printf("can't open file!
");exit(0);}for(i=0;i<n;i++){printf("学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[i].num,stu[i].name,stu[i].x_num,stu[i].class_num,stu[i].score1,stu[i].score2,stu[i].score3,stu[i].total,stu[i].average);fwrite(&stu[i],LEN,1,fp);}fclose(fp);}//(2)按平均分统计各个分数段的学生人数(不及格,60-69,70-79,80-89,90-100)。void each_score(){int e,d,c,b,a,i;a=b=c=d=e=0;for(i=0;i<n;i++){if(stu[i].average<60) e++;else if(stu[i].average<70) d++;else if(stu[i].average<80) c++;else if(stu[i].average<90) b++;else a++;}printf("不及格人数为%d
60-69人数为%d
70-79人数为%d
80-89人数为%d
90-100人数为%d
",e,d,c,b,a);}//(3)分别找出3门课程成绩最高的学生,并输出他们的信息。void high_stu(){int max1,max2,max3,i;max1=max2=max3=0;for(i=0;i<n;i++){if(stu[max1].score1<stu[i].score1) max1=i;if(stu[max2].score2<stu[i].score2) max2=i;if(stu[max3].score3<stu[i].score3) max3=i;}printf("高数最高成绩学生信息:
学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[max1].num,stu[max1].name,stu[max1].x_num,stu[max1].class_num,stu[max1].score1,stu[max1].score2,stu[max1].score3,stu[max1].total,stu[max1].average);printf("英语最高成绩学生信息:
学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f总分:%0.2f 平均分:%0.2f
",stu[max2].num,stu[max2].name,stu[max2].x_num,stu[max2].class_num,stu[max2].score1,stu[max2].score2,stu[max2].score3,stu[max2].total,stu[max2].average);printf("c语言最高成绩学生信息:
学号:%d 姓名:%s 学院代号:%d 班级号:%d 高数成绩:%0.2f 英语成绩:%0.2f c语言成绩:%0.2f 总分:%0.2f 平均分:%0.2f
",stu[max3].num,stu[max3].name,stu[max3].x_num,stu[max3].class_num,stu[max3].score1,stu[max3].score2,stu[max3].score3,stu[max3].total,stu[max3].average);}//(4)分别统计出3门课程的不及格率,并输出。void filled(){int i;float f1,f2,f3,sf1,sf2,sf3;f1=f2=f3=0;for(i=0;i<n;i++){if(stu[i].score1<60) f1++;if(stu[i].score2<60) f2++;if(stu[i].score3<60) f3++;}sf1=f1/n;sf2=f2/n;sf3=f3/n;printf("高数不及格率为%0.2f
",sf1);printf("英语不及格率为%0.2f
",sf2);printf("c语言不及格率为%0.2f
",sf3);}//统计模块void stat() {char ch;int i;if((fp=fopen("student_number","rb"))==NULL){printf("can't open file!
");exit(0);}fread(&n,sizeof(n),1,fp);if((fp=fopen("student","rb"))==NULL){printf("can't open file!
");exit(0);}for(i=0;i<n;i++)fread(&stu[i],LEN,1,fp);printf("选择要进行的统计操作代号:
1、按总分由高到低。
2、按平均分统计各个分数段的学生人数(不及格,60-69,70-79,80-89,90-100)。
3、找出3门课程成绩最高的学生。
4、统计出3门课程的不及格率。
");fflush(stdin);ch=getchar();switch(ch){case '1': totall_score(); break;case '2': each_score(); break;case '3': high_stu(); break;case '4': filled(); break;default :printf("输入代号有误。
");}begin:printf("@是否继续“统计”操作(y/n)?
");fflush(stdin);ch=getchar();if(ch=='y'||ch=='Y') stat();else if(ch=='n'||ch=='N') ;else { printf("输入有误!
"); goto begin;}}/*主选项*/void action() {char ch;printf("输入想要进行操作的代码:
1、输入学生信息;
2、增加学生信息;
3、删除学生信息;
4、修改学生信息;
5、按不同条件对学生信息进行查询操作;
6、按不同条件对学生成绩进行统计工作。
");fflush(stdin);ch=getchar();switch(ch){case '1':creat();break; //输入学生信息case '2':add();break; //增加学生信息case '3':del();break; //删除学生信息case '4':change();break; //修改学生信息case '5':search();break; //按不同条件对学生信息进行查询操作case '6':stat();break; //按不同条件对学生成绩进行统计工作default:printf("输入代号有误。
");}begin:printf("#是否继续进行“管理”操作?(y/n)
");fflush(stdin);ch=getchar();if(ch=='y'||ch=='Y') action();else if(ch=='n'||ch=='N') ;else { printf("输入有误!
"); goto begin;}}//主函数void main(){printf("~~~~~~学生成绩管理系统~~~~~~

");action();}
评论0 举报
5 0
加载更多

最新回答 (1条回答)

匿名用户 1级
2010-12-22 回答
#include#include#includeusing namespace std;struct lx{long num;char name[20];struct lx *link;};struct lx *addlist(struct lx *head,long x);//添加节点;void listclear(struct lx *head);struct lx *createlist(void );void listprintf(struct lx *p);int main(int argc,char **argv){long x;struct lx *p = createlist();listprintf(p);cout> x;struct lx *head = addlist(p,x);listprintf(head);listclear(head);//listprintf(temp);return 0;}struct lx *createlist(void ){struct lx *head ;struct lx *tail ;struct lx *p;char buf[20];head = NULL;p = (struct lx *)malloc(sizeof (struct lx));// cout> p->num;cout> p->name;//coutname, buf);while(1){if(head == NULL){head = p;tail = p;}else{tail->link = p;tail = p;}p = (struct lx*)malloc(sizeof(struct lx));// cout> p->num;if(p->num == 0)break;cout> p->name;//strcpy(p->name,buf);}tail->link = NULL;return head;}void listprintf(struct lx *p){struct lx* q = p;while(q!= NULL){ coutnumnamelink;}}struct lx *addlist(struct lx *head,long x)//添加节点{struct lx *p = head;struct lx *q,*temp,*temp1;q = NULL;if(p->link == NULL ){if((p->num ) > x ){q=(struct lx *)malloc(sizeof(struct lx));cout>q->name;q->num = x;q->link = p;p = q;}else{q=(struct lx *)malloc(sizeof(struct lx));cout>q->name;q->num = x;temp1 = p->link;p->link = q;q->link = temp1;temp1->link = NULL;}}else if(((p->num) > x)&&((p->link)->link == NULL)){q=(struct lx *)malloc(sizeof(struct lx));cout>q->name;q->num = x;p->link = q;q->link = p;q->link = NULL;}哗笭糕蝗蕹豪革通宫坤 else{while(1){if((p->num link)->num > x))break;p = p->link;}q=(struct lx *)malloc(sizeof(struct lx));cout>q->name;q->num = x;temp = p->link;p->link = q;q->link = temp;}return p; }void listclear(str

是字符型的界面吗?
我只简单写了一些,本人亲自编写:
#include <stdio.h>
#include <dos.h>
#include <string.h>
#include <stdlib.h>
#include <alloc.h>
#define SIZE 8
struct student
{
char name[20];
char num[15];
int score[5];
float ave;
struct student *next;
}stu[SIZE],temp,s;
void Inputmess()
{
int i,j,sum,length,flag=1;
FILE *fp;
while(flag==1)
{printf("Input length of list(<10):");
scanf("%d",&length);
if(length<10)
flag=0;
}
for(i=0;i<length;i++)
{printf("\ninput the student's message:");
printf("\ninput thr name:");
scanf("%s",stu[i].name);
printf("\ninput the NO.:");
scanf("%s",stu[i].num);
printf("\ninput the score:");
sum=0;
for(j=0;j<5;j++)
{printf("score %d:",j+1);
scanf("%d",&stu[i].score[j]);
sum+=stu[i].score[j];
}
stu[i].ave=sum/5.0;
}
fp=fopen("stu1","w");
for(i=0;i<length;i++)
if(fwrite(&stu[i],sizeof(struct student),1,fp)!=1)
printf("File write error\n");
fclose(fp);
fp=fopen("stu1","r");
printf("\n name NO. score1 score2 score3 score4 score5 ave\n");
for(i=0;i<length;i++)
{fread(&stu[i],sizeof(struct student),1,fp);
printf("%-15s%11s%7d%7d%7d%7d%7d%10.2f\n",stu[i].name,stu[i].num,stu[i].score[0],
stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].ave);
}
}
void search()
{ FILE *fp, *fp1;
char n[15],name[20];
int i,j,k,t,m,flag=1;
if((fp=fopen("stu1","r"))==NULL)
{printf("Can not open the file.");
exit(0);
}
printf("\noriginal data:\n");
for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++)
{printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(t=0;t<5;t++)
printf("%7d",stu[i].score[t]);
printf("%10.2f",stu[i].ave);
}
k=i;
printf("\nPlease select the menu(1.number 2.name):");
scanf("%d",&m);
switch(m)
{case 1:printf("\nSearch number:");
scanf("%s",n);
for(flag=1,i=0;i<k;i++)
{if(strcmp(n,stu[i].num)==0)
{j=i;
flag=0;
break;
}
}
break;
case 2:printf("\nSearch name:");
scanf("%s",name);
for(flag=1,i=0;i<k;i++)
{if(strcmp(name,stu[i].name)==0)
{j=i;flag=0;break;
}
}
}
if(!flag)
{printf("\nYou can find:\n");
fp1=fopen("stu2","w");
printf(" name NO. score1 score2 score3 score4 score5 ave\n");
fwrite(&stu[j],sizeof(struct student),1,fp1);
printf("%-15s%11s%7d%7d%7d%7d%7d%10.2f",stu[j].name,stu[j].num,stu[j].score[0],stu[j].score[1],
stu[j].score[2],stu[j].score[3],stu[j].score[4],stu[j].ave);
}
else printf("\nNot found!");
fclose(fp);
fclose(fp1);
}
xiugai()
{ int a;
printf("\nplease select the menu(1.CHARU 2.SHANCHU ):");
scanf("%d",&a);
switch(a)
{
case 1:Insert(); break;
case 2:Delete(); break;
}
}
Insert()
{ FILE *fp;
int i,j,t,n;
printf("\nNO.:");
scanf("%s",s.num);
printf("name:");
scanf("%s",s.name);
printf("score1,score2,score3,score4,score5:");
scanf("%d,%d,%d,%d,%d",&s.score[0],&s.score[1],&s.score[2],&s.score[3],&s.score[4]);
s.ave=(s.score[0]+s.score[1]+s.score[2]+s.score[3]+s.score[4])/5.0;
if((fp=fopen("stu1","r"))==NULL)
{printf("Can not open the file.");
exit(0);
}
printf("\noriginal data:\n");
for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++)
{printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fclose(fp);
n=i;
for(t=0;stu[t].ave>s.ave&&t<n;t++);
printf("\nnow:\n");
fp=fopen("stu1","w");
for(i=0;i<t;i++)
{fwrite(&stu[i],sizeof(struct student),1,fp);
printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fwrite(&s,sizeof(struct student),1,fp);
printf("\n%-15s%11s%7d%7d%7d%7d%7d%10.2f",s.name,s.num,s.score[0],s.score[1],
s.score[2],s.score[3],s.score[4],s.ave);
for(i=t;i<n;i++)
{fwrite(&stu[i],sizeof(struct student),1,fp);
printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fclose(fp);
}
Delete()
{ FILE *fp;
int i,j,t,n,flag;
char number[15];
if((fp=fopen("stu1","rb"))==NULL)
{printf("Can not open the file.");
exit(0);
}
printf("\noriginal data:");
for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++)
{printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fclose(fp);
n=i;
printf("\nInput number deleted:");
scanf("%s",number);
for(flag=1,i=0;flag&&i<n;i++)
{if(strcmp(number,stu[i].num)==0)
{for(t=i;t<n-1;t++)
{strcpy(stu[t].num,stu[t+1].num);
strcpy(stu[t].name,stu[t+1].name);
for(j=0;j<5;j++)
stu[t].score[j]=stu[t+1].score[j];
stu[t].ave=stu[t+1].ave;
}
flag=0;
}
}
if(!flag)
n=n-1;
else
printf("\n Not found!");
printf("\nNow,the content of file:\n");
fp=fopen("stu1","wb");
for(i=0;i<n;i++)
fwrite(&stu[i],sizeof(struct student),1,fp);
fclose(fp);
fp=fopen("stu1","r");
for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++)
printf("%-15s%11s%7d%7d%7d%7d%7d%10.2f\n",stu[i].name,stu[i].num,stu[i].score[0],
stu[i].score[1],stu[i].score[2],stu[i].score[3],stu[i].score[4],stu[i].ave);
fclose(fp);
}
paixu()
{
FILE *fp;
int i,j,n;
if((fp=fopen("stu1","r"))==NULL)
{printf("Can not open the file.");
exit(0);
}
printf("\nfile'stu1':");
for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++)
{printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fclose(fp);
n=i;
for(i=0;i<n;i++)
for(j=i+1;j<n;j++)
if(stu[i].ave<stu[j].ave)
{temp=stu[i];
stu[i]=stu[j];
stu[j]=temp;
}
printf("\nnow:");
fp=fopen("stu1","w");
for(i=0;i<n;i++)
{fwrite(&stu[i],sizeof(struct student),1,fp);
printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fclose(fp);
}
tongji()
{ FILE *fp;
int i,j,k,labe1;
float t;
if((fp=fopen("stu1","r"))==NULL)
{printf("Can not open the file.");
exit(0);
}
printf("\nfile'stu1':");
for(i=0;fread(&stu[i],sizeof(struct student),1,fp)!=0;i++)
{printf("\n%-15s%11s",stu[i].name,stu[i].num);
for(j=0;j<5;j++)
printf("%7d",stu[i].score[j]);
printf("%10.2f",stu[i].ave);
}
fclose(fp);
k=i;
for(i=0;i<k;i++)
{labe1=0;
if(stu[i].ave<60)
{labe1++;
t=labe1/(float)k*100;
}
}
printf("\nbujigelv:");
printf("%f%",t);

}
main()
{
int a;
printf("****************************************\n");
printf(" Welcome to use this System\n");
printf("****************************************\n");
while(1)
{printf("\nselect the Menu:\n");
printf("1.inputmess 2.search 3.paixu 4.xiugai 5.tongji 6.exit\n");
scanf("%d",&a);
switch(a)
{case 1: Inputmess();break;
case 2: search(); break;
case 3: paixu(); break;
case 4: xiugai(); break;
case 5: tongji();break;
case 6: exit(0);
}
}
}
肯定能运行,我已经在我的机子试过了。统计部分还没写好。在有什么功能自己加吧。今天我没时间了,而且你的悬赏分这么低。估计除了我以外不会有人再回答你的问题,800行太多了。我没这么多时间。如果你认为还可以,就在多给我一些悬赏分,好吧。

本来还有很多注释的,由于百度字数的限制,我把注释都删了一部分.
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
#include "conio.h"
#include "mem.h"
#include "ctype.h"
#include "alloc.h"
#define N 3
typedef struct z1
{
char no[11];
char name[15];
int score[N];
float sum;
float average;
int order;
struct z1 *next;
}STUDENT;

STUDENT *init();
STUDENT *create();
STUDENT *delete(STUDENT *h);
void print(STUDENT *h);
void search(STUDENT *h);
void save(STUDENT *h);
STUDENT *load();
void computer(STUDENT *h);
STUDENT *insert(STUDENT *h);
void append();
void copy();
STUDENT *sort(STUDENT *h);
STUDENT *index(STUDENT *h);
void total(STUDENT *h);
int menu_select();

main()
{
int i;
STUDENT *head;
head=init();
clrscr();
for(;;)
{
switch(menu_select())
{ case 0:head=init();break;
case 1:head=create();break;
case 2:head=delete(head);break;
case 3:print(head);break;
case 4:search(head);break;
case 5:save(head);break;
case 6:head=load(); break;
case 7:computer(head);break;
case 8:head=insert(head); break;
case 9:copy();break;
case 10:head=sort(head);break;
case 11:append();break;
case 12:head=index(head);break;
case 13:total(head);break;
case 14:exit(0);
}
}
}

menu_select()
{
char *menu[]={"***************MENU***************",
" 0. init list",
" 1. Enter list",
" 2. Delete a record from list",
" 3. print list ",
" 4. Search record on name",
" 5. Save the file",
" 6. Load the file",
" 7. compute the score",
" 8. insert record to list ",
" 9. copy the file to new file",
" 10. sort to make new file",
" 11. append record to file",
" 12. index on nomber",
" 13. total on nomber",
" 14. Quit"};
char s[3];
int c,i;
gotoxy(1,25);
printf("press any key enter menu......\n");
getch(); /*输入任一键*/
clrscr(); /*清屏幕*/
gotoxy(1,1); /*移动光标*/
textcolor(YELLOW); /*设置文本显示颜色为黄色*/
textbackground(BLUE); /*设置背景颜色为蓝色*/
gotoxy(10,2); /*移动光标*/
putch(0xc9); /*输出左上角边框┏*/
for(i=1;i<44;i++)
putch(0xcd); /*输出上边框水平线*/
putch(0xbb); /*输出右上角边框 ┓*/
for(i=3;i<20;i++)
{
gotoxy(10,i);putch(0xba); /*输出左垂直线*/
gotoxy(54,i);putch(0xba);
} /*输出右垂直线*/
gotoxy(10,20);putch(0xc8); /*输出左上角边框┗*/
for(i=1;i<44;i++)
putch(0xcd); /*输出下边框水平线*/
putch(0xbc); /*输出右下角边框┛*/
window(11,3,53,19); /* 制作显示菜单的窗口,大小根据菜单条数设计*/
clrscr(); /*清屏*/
for(i=0;i<16;i++) /*输出主菜单数组*/
{
gotoxy(10,i+1);
cprintf("%s",menu[i]);
}
textbackground(BLACK); /*设置背景颜色为黑色*/
window(1,1,80,25); /*恢复原窗口大小*/
gotoxy(10,21); /*移动光标*/
do{
printf("\n Enter you choice(0~14):"); /*在菜单窗口外显示提示信息*/
scanf("%s",s); /*输入选择项*/
c=atoi(s); /*将输入的字符串转化为整形数*/
}while(c<0||c>14); /*选择项不在0~14之间重输*/
return c; /*返回选择项,主程序根据该数调用相应的函数*/
}
STUDENT *init()
{
return NULL;
}

/*创建链表*/
STUDENT *create()
{
int i; int s;
STUDENT *h=NULL,*info; /* STUDENT指向结构体的指针*/
for(;;)
{
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info) /*如果指针info为空*/
{
printf("\nout of memory"); /*输出内存溢出*/
return NULL; /*返回空指针*/
}
inputs("enter no:",info->no,11); /*输入学号并校验*/
if(info->no[0]=='@') break; /*如果学号首字符为@则结束输入*/
inputs("enter name:",info->name,15); /*输入姓名,并进行校验*/
printf("please input %d score \n",N); /*提示开始输入成绩*/
s=0; /*计算每个学生的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次*/
{
do{
printf("score%d:",i+1); /*提示输入第几门课程*/
scanf("%d",&info->score[i]); /*输入成绩*/
if(info->score[i]>100||info->score[i]<0) /*确保成绩在0~100之间*/
printf("bad data,repeat input\n"); /*出错提示信息*/
}while(info->score[i]>100||info->score[i]<0);
s=s+info->score[i]; /*累加各门课程成绩*/
}
info->sum=s; /*将总分保存*/
info->average=(float)s/N; /*求出平均值*/
info->order=0; /*未排序前此值为0*/
info->next=h; /*将头结点做为新输入结点的后继结点*/
h=info; /*新输入结点为新的头结点*/
}
return(h); /*返回头指针*/
}
/*输入字符串,并进行长度验证*/
inputs(char *prompt, char *s, int count)
{
char p[255];
do{
printf(prompt); /*显示提示信息*/
scanf("%s",p); /*输入字符串*/
if(strlen(p)>count)printf("\n too long! \n"); /*进行长度校验,超过count值重输入*/
}while(strlen(p)>count);
strcpy(s,p); /*将输入的字符串拷贝到字符串s中*/
}
/*输出链表中结点信息*/
void print(STUDENT *h)
{
int i=0; /* 统计记录条数*/
STUDENT *p; /*移动指针*/
clrscr(); /*清屏*/
p=h; /*初值为头指针*/
printf("\n\n\n****************************STUDENT********************************\n");
printf("|rec|nO | name | sc1| sc2| sc3| sum | ave |order|\n");
printf("|---|----------|---------------|----|----|----|--------|-------|-----|\n");
while(p!=NULL)
{
i++;
printf("|%3d |%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", i, p->no,p->name,p->score[0],p->score[1],
p->score[2],p->sum,p->average,p->order);
p=p->next;
}
printf("**********************************end*********************************\n");
}
/*删除记录*/
STUDENT *delete(STUDENT *h)
{
STUDENT *p,*q; /*p为查找到要删除的结点指针,q为其前驱指针*/
char s[11]; /*存放学号*/
clrscr(); /*清屏*/
printf("please deleted no\n"); /*显示提示信息*/
scanf("%s",s); /*输入要删除记录的学号*/
q=p=h; /*给q和p赋初值头指针*/
while(strcmp(p->no,s)&&p!=NULL) /*当记录的学号不是要找的,或指针不为空时*/
{
q=p; /*将p指针值赋给q作为p的前驱指针*/
p=p->next; /*将p指针指向下一条记录*/
}
if(p==NULL) /*如果p为空,说明链表中没有该结点*/
printf("\nlist no %s student\n",s);
else /*p不为空,显示找到的记录信息*/
{
printf("*****************************have found***************************\n");
printf("|no | name | sc1| sc2| sc3| sum | ave |order|\n");
printf("|----------|---------------|----|----|----|--------|-------|-----|\n");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,
p->average,p->order);
printf("********************************end*******************************\n");
getch(); /*压任一键后,开始删除*/
if(p==h) /*如果p==h,说明被删结点是头结点*/
h=p->next; /*修改头指针指向下一条记录*/
else
q->next=p->next; /*不是头指针,将p的后继结点作为q的后继结点*/
free(p); /*释放p所指结点空间*/
printf("\n have deleted No %s student\n",s);
printf("Don't forget save\n");/*提示删除后不要忘记保存文件*/
}
return(h); /*返回头指针*/
}
/*查找记录*/
void search(STUDENT *h)
{
STUDENT *p; /* 移动指针*/
char s[15]; /*存放姓名的字符数组*/
clrscr(); /*清屏幕*/
printf("please enter name for search\n");
scanf("%s",s); /*输入姓名*/
p=h; /*将头指针赋给p*/
while(strcmp(p->name,s)&&p!=NULL) /*当记录的姓名不是要找的,或指针不为空时*/
p=p->next; /*移动指针,指向下一结点*/
if(p==NULL) /*如果指针为空*/
printf("\nlist no %s student\n",s); /*显示没有该学生*/
else /*显示找到的记录信息*/
{
printf("\n\n*****************************havefound***************************\n");
printf("|nO | name | sc1| sc2| sc3| sum | ave |order|\n");
printf("|----------|---------------|----|----|----|--------|-------|-----|\n");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);
printf("********************************end*******************************\n");
}
}
/*插入记录*/
STUDENT *insert(STUDENT *h)
{
STUDENT *p,*q,*info; /*p指向插入位置,q是其前驱,info指新插入记录*/
char s[11]; /*保存插入点位置的学号*/
int s1,i;
printf("please enter location before the no\n");
scanf("%s",s); /*输入插入点学号*/
printf("\nplease new record\n"); /*提示输入记录信息*/
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
{
printf("\nout of memory"); /*如没有申请到,内存溢出*/
return NULL; /*返回空指针*/
}
inputs("enter no:",info->no,11); /*输入学号*/
inputs("enter name:",info->name,15); /*输入姓名*/
printf("please input %d score \n",N); /*提示输入分数*/
s1=0; /*保存新记录的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次输入成绩*/
{
do{ /*对数据进行验证,保证在0~100之间*/
printf("score%d:",i+1);
scanf("%d",&info->score[i]);
if(info->score[i]>100||info->score[i]<0)
printf("bad data,repeat input\n");
}while(info->score[i]>100||info->score[i]<0);
s1=s1+info->score[i]; /*计算总分*/
}
info->sum=s1; /*将总分存入新记录中*/
info->average=(float)s1/N; /*计算均分*/
info->order=0; /*名次赋值0*/
info->next=NULL; /*设后继指针为空*/
p=h; /*将指针赋值给p*/
q=h; /*将指针赋值给q*/
while(strcmp(p->no,s)&&p!=NULL) /*查找插入位置*/
{
q=p; /*保存指针p,作为下一个p的前驱*/
p=p->next; /*将指针p后移*/
}
if(p==NULL) /*如果p指针为空,说明没有指定结点*/
if(p==h) /*同时p等于h,说明链表为空*/
h=info; /*新记录则为头结点*/
else
q->next=info; /*p为空,但p不等于h,将新结点插在表尾*/
else
if(p==h) /*p不为空,则找到了指定结点*/
{
info->next=p; /*如果p等于h,则新结点插入在第一个结点之前*/
h=info; /*新结点为新的头结点*/
}
else
{
info->next=p; /*不是头结点,则是中间某个位置,新结点的后继为p*/
q->next=info; /*新结点作为q的后继结点*/
}
printf("\n ----have inserted %s student----\n",info->name); printf("---Don't forget save---\n"); /*提示存盘*/
return(h); /*返回头指针*/
}
/*保存数据到文件*/
void save(STUDENT *h)
{
FILE *fp; /*定义指向文件的指针*/
STUDENT *p; /* 定义移动指针*/
char outfile[10]; /*保存输出文件名*/
printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示文件名格式信息*/
scanf("%s",outfile);
if((fp=fopen(outfile,"wb"))==NULL) /*为输出打开一个二进制文件,如没有则建立*/
{
printf("can not open file\n");
exit(1);
}
printf("\nSaving file......\n"); /*打开文件,提示正在保存*/
p=h; /*移动指针从头指针开始*/
while(p!=NULL) /*如p不为空*/
{
fwrite(p,sizeof(STUDENT),1,fp);/*写入一条记录*/
p=p->next; /*指针后移*/
}
fclose(fp); /*关闭文件*/
printf("-----save success!!-----\n"); /*显示保存成功*/
}
/* 从文件读数据*/
STUDENT *load()
{
STUDENT *p,*q,*h=NULL; /*定义记录指针变量*/
FILE *fp; /* 定义指向文件的指针*/
char infile[10]; /*保存文件名*/
printf("Enter infile name,for example c:\\f1\\te.txt:\n"); scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"rb"))==NULL) /*打开一个二进制文件,为读方式*/
{
printf("can not open file\n"); /*如不能打开,则结束程序*/
exit(1);
}
printf("\n -----Loading file!-----\n");
p=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!p)
{
printf("out of memory!\n"); /*如没有申请到,则内存溢出*/
return h; /*返回空头指针*/
}
h=p; /*申请到空间,将其作为头指针*/
while(!feof(fp)) /*循环读数据直到文件尾结束*/
{
if(1!=fread(p,sizeof(STUDENT),1,fp))
break; /*如果没读到数据,跳出循环*/
p->next=(STUDENT *)malloc(sizeof(STUDENT)); /*为下一个结点申请空间*/
if(!p->next)
{
printf("out of memory!\n"); /*如没有申请到,则内存溢出*/
return h;
}
q=p; /*保存当前结点的指针,作为下一结点的前驱*/
p=p->next; /*指针后移,新读入数据链到当前表尾*/
}
q->next=NULL; /*最后一个结点的后继指针为空*/
fclose(fp); /*关闭文件*/
printf("---You have success read data from file!!!---\n");
return h; /*返回头指针*/
}
/*追加记录到文件*/
void append()
{
FILE *fp; /*定义指向文件的指针*/
STUDENT *info; /*新记录指针*/
int s1,i;
char infile[10]; /*保存文件名*/
printf("\nplease new record\n");
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
{
printf("\nout of memory"); /*没有申请到,内存溢出本函数结束*/
return ;
}
inputs("enter no:",info->no,11); /*调用inputs输入学号*/
inputs("enter name:",info->name,15); /*调用inputs输入姓名*/
printf("please input %d score \n",N); /*提示输入成绩*/
s1=0;
for(i=0;i<N;i++)
{
do{
printf("score%d:",i+1);
scanf("%d",&info->score[i]); /*输入成绩*/
if(info->score[i]>100||info->score[i]<0)printf("bad data,repeat input\n");
}while(info->score[i]>100||info->score[i]<0); /*成绩数据验证*/
s1=s1+info->score[i]; /*求总分*/
}
info->sum=s1; /*保存总分*/
info->average=(float)s1/N; /*求均分*/
info->order=0; /*名次初始值为0*/
info->next=NULL; /*将新记录后继指针赋值为空*/
printf("Enter infile name,for example c:\\f1\\te.txt:\n"); scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"ab"))==NULL) /*向二进制文件尾增加数据方式打开文件*/
{
printf("can not open file\n"); /*显示不能打开*/
exit(1); /*退出程序*/
}
printf("\n -----Appending record!-----\n");
if(1!=fwrite(info,sizeof(STUDENT),1,fp)) /*写文件操作*/
{
printf("-----file write error!-----\n");
return; /*返回*/
}
printf("-----append sucess!!----\n");
fclose(fp); /*关闭文件*/
}
/*文件拷贝*/
void copy()
{
char outfile[10],infile[10];
FILE *sfp,*tfp; /*源和目标文件指针*/
STUDENT *p=NULL; /*移动指针*/
clrscr(); /*清屏*/
printf("Enter infile name,for example c:\\f1\\te.txt:\n");
scanf("%s",infile); /*输入源文件名*/
if((sfp=fopen(infile,"rb"))==NULL) /*二进制读方式打开源文件*/
{
printf("can not open input file\n");
exit(0);
}
printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示输入目标文件名*/
scanf("%s",outfile); /*输入目标文件名*/
if((tfp=fopen(outfile,"wb"))==NULL) /*二进制写方式打开目标文件*/
{
printf("can not open output file \n");
exit(0);
}
while(!feof(sfp)) /*读文件直到文件尾*/
{
if(1!=fread(p,sizeof(STUDENT),1,sfp))
break; /*块读*/
fwrite(p,sizeof(STUDENT),1,tfp); /*块写*/
}
fclose(sfp); /*关闭源文件*/
fclose(tfp); /*关闭目标文件*/
printf("you have success copy file!!!\n"); /*显示成功拷贝*/
}
/*排序*/
STUDENT *sort(STUDENT *h)
{
int i=0; /*保存名次*/
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*第一个结点为新表的头结点*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
{
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(t->sum<p->sum&&p!=NULL) /*作总分比较*/
{
q=p; /*待排序点值小,则新表指针后移*/
p=p->next;
}
if(p==q) /*p==q,说明待排序点值大,应排在首位*/
{
t->next=p; /*待排序点的后继为p*/
h=t; /*新头结点为待排序点*/
}
else /*待排序点应插入在中间某个位置q和p之间,如p为空则是尾部*/
{
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/
}
}
p=h; /*已排好序的头指针赋给p,准备填写名次*/
while(p!=NULL) /*当p不为空时,进行下列操作*/
{
i++; /*结点序号*/
p->order=i; /*将名次赋值*/
p=p->next; /*指针后移*/
}
printf("sort sucess!!!\n"); /*排序成功*/
return h; /*返回头指针*/
}
/*计算总分和均值*/
void computer(STUDENT *h)
{
STUDENT *p; /*定义移动指针*/
int i=0; /*保存记录条数初值为0*/
long s=0; /*总分初值为0*/
float average=0; /*均分初值为0*/
p=h; /*从头指针开始*/
while(p!=NULL) /*当p不为空时处理*/
{
s+=p->sum; /*累加总分*/
i++; /*统计记录条数*/
p=p->next; /*指针后移*/
}
average=(float)s/i;/* 求均分,均分为浮点数,总分为整数,所以做类型转换*/
printf("\n--All students sum score is:%ld average is %5.2f\n",s,average);
}
/*索引*/
STUDENT *index(STUDENT *h)
{
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*第一个结点为新表的头结点*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
{
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(strcmp(t->no,p->no)>0&&p!=NULL) /*作学号比较*/
{
q=p; /*待排序点值大,应往后插,所以新表指针后移*/
p=p->next;
}
if(p==q) /*p==q,说明待排序点值小,应排在首位*/
{
t->next=p; /*待排序点的后继为p*/
h=t; /*新头结点为待排序点*/
}
else /*待排序点应插入在中间某个位置q和p之间,如p为空则是尾部*/
{
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/
}
}
printf("index sucess!!!\n"); /*索引排序成功*/
return h; /*返回头指针*/
}
/*分类合计*/
void total(STUDENT *h)
{
STUDENT *p,*q; /*定义临时指针变量*/
char sno[9],qno[9],*ptr; /*保存班级号的*/
float s1,ave; /*保存总分和均分*/
int i; /*保存班级人数*/
clrscr(); /*清屏*/
printf("\n\n *******************Total*****************\n");
printf("---class---------sum--------------average----\n");
p=h; /*从头指针开始*/
while(p!=NULL) /*当p不为空时做下面的处理*/
{
memcpy(sno,p->no,8); /*从学号中取出班级号*/
sno[8]='\0'; /*做字符串结束标记*/
q=p->next; /*将指针指向待比较的记录*/
s1=p->sum; /*当前班级的总分初值为该班级的第一条记录总分*/
ave=p->average; /*当前班级的均分初值为该班级的第一条记录均分*/
i=1; /*统计当前班级人数*/
while(q!=NULL) /*内循环开始*/
{
memcpy(qno,q->no,8); /*读取班级号*/
qno[8]='\0'; /*做字符串结束标记*/
if(strcmp(qno,sno)==0) /*比较班级号*/
{
s1+=q->sum; /*累加总分*/
ave+=q->average; /*累加均分*/
i++; /*累加班级人数*/
q=q->next; /*指针指向下一条记录*/
}
else
break; /*不是一个班级的结束本次内循环*/
}
printf("%s %10.2f %5.2f\n",sno,s1,ave/i);
if(q==NULL)
break; /*如果当前指针为空,外循环结束,程序结束*/
else
p=q; /*否则,将当前记录作为新的班级的第一条记录开始新的比较*/
}
printf("---------------------------------------------\n");
}


祁县19267069329: 编程如何用C语言编写一个学生成绩管理系统程序 -
宫泼恩格: 我们才做了这个作业... #include <malloc.h> #include <stdio.h> #include <stdlib.h> #define LEN sizeof(struct scorenode) #define DEBUG #include <string.h> struct scorenode { int number;/*学号*/ char name[8];/*姓名*/ float cj1;/*成绩1*/ ...

祁县19267069329: 求一个学生成绩管理系统的C语言代码!!急!! -
宫泼恩格: #includestruct student { char num[10];char name[20];char sex[5];float grade[7];float v;float sum;}stu[50]; int k=0;void input(); void output(); void search(); void average(); void sort(); void save(); void main() { int a;do{printf("\n\n **************...

祁县19267069329: 怎么用c语言编写一个学生成绩管理系统啊?急…… -
宫泼恩格: C语言课程设计报告-------学生成绩简单管理程序 一、系统菜单的主要功能 (1)输入若干条记录 (2)显示所有记录 (3)按学号排序 (4)插入一条记录 (5)按姓名查找,删除一条记录 (6)查找并显示一条记录 (7)输出统计信息 (新增)...

祁县19267069329: 如何用C语言编一个学生成绩管理系统 -
宫泼恩格: #include "stdio.h"#include "stdlib.h"#include "string.h"#define NULL 0 int shoudsave=0; struct student { char num[10]; char name[20]; char sex[4]; int cgrade; int mgrade; int egrade; int totle; int ave; char neartime[10]; }; typedef struct node { ...

祁县19267069329: 用C语言完成学生成绩管理系统 -
宫泼恩格: #include<stdio.h> #include<conio.h> #include <stdlib.h> #include<string.h> #define MAX 100void input(); void sort(); void show(); void del(); void quit(); int i=0; int k,j; char ch;struct student {int no;char name[20];float score1;float score2;float ...

祁县19267069329: C语言编程 学生成绩管理系统 -
宫泼恩格: 这是我们大一时候课程设计做的,学生成绩管理系统,功能比楼主需要的稍多一些,你看一下,不需要的函数删掉它好了.#include<stdio.h> #include<malloc.h> #include<string.h>struct stu {long num;char name[20];float score1,score2,score...

祁县19267069329: c语言设计学生成绩管理系统 -
宫泼恩格: #include<iostream> #include<cstdio> #include<cmath> #include<vector> #include<list> #include<cstring> #include<map> #include<set> #include<algorithm> #include<queue> using namespace std; int n; struct birth {int year,month,day; };struct ...

祁县19267069329: c语言编写学生成绩管理系统 -
宫泼恩格: #include <stdio.h> void main() { /*输入资料*/ int student[5][4],i; for (i=0; i<=4; i++); scanf("%d,%d,%d \n",student[i][0],student[i][1],student[i][2],student[i][3]) /*平均分*/ for (i=0; i<=4; i++); printf("%f",(float)((student[i][1]+student[i][2]+student[i][3]...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网