
#include<stdlib.h>
#include<stdio.h>
#include<string.h>
#include<conio.h>
#define N 10
/*****定义结构体*****/
typedef struct students/*标记为students*/
{
char name[10] /*学生姓名*/
int age /*年龄*/
char sex[10] /*性别*/
float cyy /*C语言成绩*/
float computer/*计算机成绩*/
float english /*英语成绩*/
float pj /*平均成绩*/
}STU
STU temp
void sort(STU students[],int n)//排序
void save(STU students[] ,int n)//导出
int Locate(STU students[],int n)//查询
/*--------------显示菜单--------------------*/
char displaymenu()
{
char k
system("cls")
printf(" 学生成绩管理\n")
printf("-----------------------------------应用菜单-------------------------------------\n")
printf(" 1 输入学生成绩\n\n")
printf(" 2 输出学生成绩\n\n")
printf(" 3 查询学生成绩\n\n")
printf(" 4 修改学生成绩\n\n")
printf(" 5 查看成绩排序\n\n")
printf(" 6 查看成绩统计\n\n")
printf(" 7 保存数据\n\n")
printf(" 8 读取数据\n\n")
printf(" 9 退出系统\n\n")
printf(" 请选择你想进行的 *** 作:")
k=getchar()
return k
}
/*****定义输出函数*****/
void printheader() /*格式化输出表头*/
{
printf("\n\n************************学生成绩管理系统****************************\n\n\n")
printf("| 学号 | 姓名 | 年龄 | 性别 | C语言成绩 |计算机成绩 | 英语成绩| 平均成绩 | \n")
}
void printdata(STU pp) /*格式化输出表中数据*/
{
STU* p
p=&pp
printf("| %-5s| %-5s | %-4d| %-4s| %-6.0f| %-6.0f|%-5.0f|%-6.0f|\n",p->num,p->name,p->age,p->sex,p->cyy,p->computer,p->english,p->pj)
}
/*****添加学生信息*****/
int add(STU students[] ,int *n)
{
int i=0
system("cls")
printf(" \n")
printf("请输入学生信息\n")
printf(" 退出请在学生号处输入:0 \n")
printf("请输入学生学号:\n ")
scanf("%s",students[i].num)
while(strcmp(students[i].num,"0") )//当输入的学号为0时结束输入
{
printf("请输入学生姓名:\n ")
scanf("%s",students[i].name)
printf("****************\n\n\n")
printf("请输入学生年龄:\n ")
scanf("%d",&students[i].age)
printf("****************\n\n\n")
printf("请输入学生性别:\n")
scanf("%s",students[i].sex)
printf("****************\n\n\n")
printf("请输入C语言成绩:\n ")
scanf("%f",&students[i].cyy)
printf("****************\n\n\n")
printf("请输入计算机成绩:\n ")
scanf("%f",&students[i].computer)
printf("****************\n\n\n")
printf("请输入英语成绩:\n ")
scanf("%f",&students[i].english)
printf("****************\n\n\n")
students[i].pj=(students[i].cyy+students[i].computer+students[i].english)/3
printf("学生平均成绩: %-8.0f\n",students[i].pj)
i++
printf("****************\n\n\n")
printf("请输入学生学号:\n ")
scanf("%s",students[i].num)
}
*n=i
save(students ,i)
return i
}
/*****查询学生信息函数*****/
int Locate(STU students[],int n)
{
int k,m=-1
char num[10],name[20]
int i=0
system("cls")
printf(" 退出请输入:0 \n")
printf("请选择以什么方式查询:1).按学生学号查询 2).按学生姓名查询 \n")
scanf("%d",&k)
if(k==1)
{
printf("请输入你要查询的学生学号:\n")
scanf("%s",num)
while(i<n)
{
if(strcmp(students[i].num,num)==0) /*若找到学号*/
{
printf(">>学生学号:%s\n*学生姓名:%s\n*学生年龄:%d\n*学生性别:%s\n>C语言成绩:%-8.0f\n>计算机成绩:%-8.0f\n>>英语成绩:%-8.0f\n>>平均成绩:%-8.0f\n",students[i].num,students[i].name,students[i].age,students[i].sex,students[i].cyy,students[i].computer,students[i].english,students[i].pj)
m=i
getchar()
break
}
i++
}
if(i>=n)
printf("没有所找学生信息\n")
getchar()
}
else if(k==2)
{
printf("请输入你要查询的学生姓名:\n")
scanf("%s",name)
while(i<n)
{
if(strcmp(students[i].name,name)==0) /*若找到姓名*/
{ printf("学生学号:%s\n学生姓名:%s\n学生年龄:%d\n学生性别:%s\n学生C语言成绩:%-8.0f\n计算机成绩:%-8.0f\n英语成绩:%-8.0f\n平均成绩:%-8.0f\n",students[i].num,students[i].name,students[i].age,students[i].sex,students[i].cyy,students[i].computer,students[i].english,students[i].pj)
m=i
getchar()
break
}
i++
}
if(i>=n)
printf("没有所找学生信息\n")
}
return m/*返回一个根m便于修改学生信息*/
getchar()
}
/*****显示函数*****/
void input(STU students[],int n)
{
int i
system("cls")//清屏
if(n==0) /*表示没有学生信息记录*/
{
printf("\n没有学生记录!\n")
}
printf("\n\n")
printheader()/*输出表格头部*/
i=0
while(i<n)/*逐条输出数组中存储的学生信息*/
{
printdata(students[i])
i++
}
getchar()
}
/*****修改子程序*****/
void Modify(STU students[],int n)
{
int i
if(n<=0)
{
system("cls")
printf(" \n退出请输入:0 \n")
printf("\n----------not found!----------\n")
getchar()
return
}
system("cls")
printf("修改学生信息")
input(students,n)
i=Locate(students,n)/*查询到该数组元素,并返回下标值*/
if(i!=-1) /*若i!=-1,表明已经找到该数组元素*/
{
printf("请输入新的学生信息: \n")
printf(" 学号: ")
scanf("%s",students[i].num)
printf(" 姓名: ")
scanf("%s",students[i].name)
printf(" 年龄: ")
scanf("%d",&students[i].age)
printf(" 性别: ")
scanf("%s",students[i].sex)
printf(" C语言: ")
scanf("%f",&students[i].cyy)
printf(" 英语: ")
scanf("%f",&students[i].english)
printf("计算机: ")
scanf("%f",&students[i].computer)
students[i].pj=(students[i].cyy+students[i].english+students[i].computer)/3
printf("平均成绩: %-9.0f\n",students[i].pj)
save(students ,n)
printf("\n-------------修改成功!-------------\n")
}
else
printf("not found!\n")
getchar()
}
/*****学生成绩排序子程序*****/
void sort(STU students[],int n)
{
int i,j,a,b,c,d,e,f,k
float p
printf(" \n退出请输入:0 \n")
printf("成绩排序方式选择: 1.按C语言2.按英语3.按平均\n ")
scanf("%d",&k)
if(k==1)/*用选择法对C语言排序*/
{
for(i=0i<ni++)
for(j=0j<n-1j++)
{
if(students[i].english<students[j+1].english)
{
temp=students[i]
students[i]=students[j+1]
students[j+1]=temp
}
}
}
else if(k==2)/*英语用冒泡法*/
{
for(a=0a<n-1a++)
{
c=a
for(b=a+1b<nb++)
if(students[b].cyy>students[c].cyy)
c=b
if (c!=a)
{
temp=students[a]
students[a]=students[c]
students[c]=temp
}
}
}
if(k==3) /*平均成绩用插入法*/
{
for(d=1d<nd++)
{
p=students[d].pj
for(e=0e<de++)
if(students[e].pj<p)
break
if(e==d)
continue
for(f=df>ef--)
students[f]=students[f-1]
students[e]=temp
}
}
input(students,n) /*显示排序后的所有记录*/
save(students ,n)
printf("\n 排序完成!\n")
}
/*****统计学生分数在各等级的人数子程序*****/
void Tongji(STU students[],int n)
{
int count6085=0,count85=0,count60=0
int i=0
system("cls")
printf(" \n退出请输入:0 \n")
input(students,n)
i=0
while(i<n)
{
if(students[i].pj>85) {count85++i=i+1continue} /*平均成绩=>85*/
if(students[i].pj>=60&&students[i].pj<=85) {count6085++i=i+1continue} /*60<平均成绩<85*/
if(students[i].pj<60) {count60++i=i+1continue} /*平均成绩<60*/
}
printf("\n************统计结果************\n\n")
printf("平均成绩高于85分的人数:%d \n",count85)
printf(" \n")
printf("平均成绩在65分和80分之间的人数:%d \n",count6085)
printf(" \n")
printf("平均成绩低于60分的人数:%d \n",count60)
printf(" \n")
printf("\n\n**********统计结束**********")
getchar()
}
/*****导出或保存数据*****/
void save(STU students[],int n)
{
FILE* fp
int i=0
fp=fopen("students","wb+")/*以读写方式打开创建一个二进制文件*/
if(fp==NULL) /*打开文件失败*/
{
printf("\n*******打开文件错误!*******\n")
return
}
for(i=0i<ni++)
{
if(fwrite(&students[i],sizeof(STU),1,fp)==1)/*每次写一条记录或一个结构数组元素至文件*/
{
continue
}
else
{
break
}
}
if(i>0)
{
getchar()
printf("\n\n*共导出%d个学生信息*\n",i)
getchar()
}
else
{
system("cls")
printf("**没有信息导出*\n")
getchar()
}
fclose(fp)/*关闭此文件*/
}
/*****导入数据*****/
void Read(STU students[],int * n)
{
FILE* fp
int i=0
fp=fopen("students","rb")/*以只读方式打开一个已有的二进制文件*/
if(fp==NULL) /*打开文件失败*/
{
printf("\n********打开文件错误!********\n")
exit(0)
}
for(i=0i<Ni++)
{
if(fread(&students[i],sizeof(STU),1,fp)==1)/*每次读一条记录或一个结构数组元素至文件*/
continue
else
break
}
*n=i
if(i>0)
{
printf("\n\n************共导入:%d 个学生信息 ************\n",i)
getchar()
}
else
{ system("cls")
printf("************没有信息导入!************\n")
getchar()
}
getchar()
fclose(fp)/*关闭此文件*/
}
/*****主函数*****/
void main()
{
STU students[N]
int n
char s1[3],s2[3]={"1"}
int i,k
printf("\n\n")
printf("******************************************************\n")
printf("^<欢迎使用本软件> ^\n\n")
printf("^ <版本 : oooo> ^\n\n\n")
printf("^ <姓名>:卢景光 <班级>: 09623 <学号>:34 ^\n")
printf("^^\n")
printf("******************************************************\n")
printf("\n\n")
for(i=0i<3i++)
{
printf("\n请输入密码:")
gets(s1)
if(strcmp(s1,s2)==0)
break
else
printf("\n>密码错误,请重新输入")
}
if(i>2)
{
printf("\n您已连续3次输错,系统将退出!\n")
exit(0)
}
else
{
while(1)
{
k=displaymenu()
switch(k)
{
case '1' : add(students,&n)break
case '2' : Read(students,&n)input(students,n) break
case '3' : Read(students,&n)Locate(students,n)break
case '4' : Read(students,&n)Modify(students,n)break
case '5' : Read(students,&n)sort(students,n)break
case '6' : Read(students,&n)Tongji(students,n)break
case '7' : save(students,n) break
case '8' : Read(students,&n)break
case '9' : system("cls")
printf("\n **********谢谢您的使用**********\n")exit(0)break
default : printf("\n\n输入错误,输入必须是0~9之间的一个数字!请重新输入\n")getchar()getchar()
}
}
}
}
#include "stdio.h"#include "stdlib.h"
#include "string.h"
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
{
struct student data
struct node *next
}Node,*Link
void menu()
{
printf("********************************************************************************")
printf("\t1登记学生资料\t\t\t\t\t2删除学生资料\n")
printf("\t3查询学生资料\t\t\t\t\t4修改学生资料\n")
printf("\t5保存学生资料\t\t\t\t\t0退出系统\n")
printf("********************************************************************************\n")
}
void printstart()
{
printf("-----------------------------------------------------------------------\n")
}
void Wrong()
{
printf("\n=====>提示:输入错误!\n")
}
void Nofind()
{
printf("\n=====>提示:没有找到该学生!\n")
}
void printc() /* 本函数用于输出中文 */
{
printf(" 学号\t 姓名 性别 英语成绩 数学成绩 C语言成绩 总分 平均分\n")
}
void printe(Node *p)/* 本函数用于输出英文 */
{
printf("%-12s%s\t%s\t%d\t%d\t%d\t %d\t %d\n",p->data.num,p->data.name,p->data.sex,p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.totle,p->data.ave)
}
Node* Locate(Link l,char findmess[],char nameornum[]) /* 该函数用于定位连表中符合要求的接点,并返回该指针 */
{
Node *r
if(strcmp(nameornum,"num")==0) /* 按学号查询 */
{
r=l->next
while(r!=NULL)
{
if(strcmp(r->data.num,findmess)==0)
return r
r=r->next
}
}
else if(strcmp(nameornum,"name")==0) /* 按姓名查询 */
{
r=l->next
while(r!=NULL)
{
if(strcmp(r->data.name,findmess)==0)
return r
r=r->next
}
}
return 0
}
void Add(Link l) /* 增加学生 */
{
Node *p,*r,*s
char num[10]
r=l
s=l->next
while(r->next!=NULL)
r=r->next/* 将指针置于最末尾 */
while(1)
{
printf("请你输入学号(以'0'返回上一级菜单:)")
scanf("%s",num)
if(strcmp(num,"0")==0)
break
while(s)
{
if(strcmp(s->data.num,num)==0)
{
printf("=====>提示:学号为'%s'的学生已经存在,若要修改请你选择'4 修改'!\n",num)
printstart()
printc()
printe(s)
printstart()
printf("\n")
return
}
s=s->next
}
p=(Node *)malloc(sizeof(Node))
strcpy(p->data.num,num)
printf("请你输入姓名:")
scanf("%s",p->data.name)
getchar()
printf("请你输入性别:")
scanf("%s",p->data.sex)
getchar()
printf("请你输入c语言成绩:")
scanf("%d",&p->data.cgrade)
getchar()
printf("请你输入数学成绩:")
scanf("%d",&p->data.mgrade)
getchar()
printf("请你输入英语成绩:")
scanf("%d",&p->data.egrade)
getchar()
p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade
p->data.ave=p->data.totle / 3
/* 信息输入已经完成 */
p->next=NULL
r->next=p
r=p
shoudsave=1
}
}
void Qur(Link l) /* 查询学生 */
{
int sel
char findmess[20]
Node *p
if(!l->next)
{
printf("\n=====>提示:没有资料可以查询!\n")
return
}
printf("\n=====>1按学号查找\n=====>2按姓名查找\n")
scanf("%d",&sel)
if(sel==1)/* 学号 */
{
printf("请你输入要查找的学号:")
scanf("%s",findmess)
p=Locate(l,findmess,"num")
if(p)
{
printf("\t\t\t\t查找结果\n")
printstart()
printc()
printe(p)
printstart()
}
else
Nofind()
}
else if(sel==2) /* 姓名 */
{
printf("请你输入要查找的姓名:")
scanf("%s",findmess)
p=Locate(l,findmess,"name")
if(p)
{
printf("\t\t\t\t查找结果\n")
printstart()
printc()
printe(p)
printstart()
}
else
Nofind()
}
else
Wrong()
}
void Del(Link l) /* 删除 */
{
int sel
Node *p,*r
char findmess[20]
if(!l->next)
{
printf("\n=====>提示:没有资料可以删除!\n")
return
}
printf("\n=====>1按学号删除\n=====>2按姓名删除\n")
scanf("%d",&sel)
if(sel==1)
{
printf("请你输入要删除的学号:")
scanf("%s",findmess)
p=Locate(l,findmess,"num")
if(p)
{
r=l
while(r->next!=p)
r=r->next
r->next=p->next
free(p)
printf("\n=====>提示:该学生已经成功删除!\n")
shoudsave=1
}
else
Nofind()
}
else if(sel==2)
{
printf("请你输入要删除的姓名:")
scanf("%s",findmess)
p=Locate(l,findmess,"name")
if(p)
{
r=l
while(r->next!=p)
r=r->next
r->next=p->next
free(p)
printf("\n=====>提示:该学生已经成功删除!\n")
shoudsave=1
}
else
Nofind()
}
else
Wrong()
}
void Modify(Link l)
{
Node *p
char findmess[20]
if(!l->next)
{
printf("\n=====>提示:没有资料可以修改!\n")
return
}
printf("请你输入要修改的学生学号:")
scanf("%s",findmess)
p=Locate(l,findmess,"num")
if(p)
{
printf("请你输入新学号(原来是%s):",p->data.num)
scanf("%s",p->data.num)
printf("请你输入新姓名(原来是%s):",p->data.name)
scanf("%s",p->data.name)
getchar()
printf("请你输入新性别(原来是%s):",p->data.sex)
scanf("%s",p->data.sex)
printf("请你输入新的c语言成绩(原来是%d分):",p->data.cgrade)
scanf("%d",&p->data.cgrade)
getchar()
printf("请你输入新的数学成绩(原来是%d分):",p->data.mgrade)
scanf("%d",&p->data.mgrade)
getchar()
printf("请你输入新的英语成绩(原来是%d分):",p->data.egrade)
scanf("%d",&p->data.egrade)
p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade
p->data.ave=p->data.totle/3
printf("\n=====>提示:资料修改成功!\n")
shoudsave=1
}
else
Nofind()
}
void Disp(Link l)
{
int count=0
Node *p
p=l->next
if(!p)
{
printf("\n=====>提示:没有资料可以显示!\n")
return
}
printf("\t\t\t\t显示结果\n")
printstart()
printc()
printf("\n")
while(p)
{
printe(p)
p=p->next
}
printstart()
printf("\n")
}
void Tongji(Link l)
{
Node *pm,*pe,*pc,*pt,*pa/* 用于指向分数最高的接点 */
Node *r=l->next
if(!r)
{
printf("\n=====>提示:没有资料可以统计!\n")
return
}
pm=pe=pc=pt=pa=r
while(r!=NULL)
{
if(r->data.cgrade>=pc->data.cgrade)
pc=r
if(r->data.mgrade>=pm->data.mgrade)
pm=r
if(r->data.egrade>=pe->data.egrade)
pe=r
if(r->data.totle>=pt->data.totle)
pt=r
if(r->data.ave>=pa->data.ave)
pa=r
r=r->next
}
printf("------------------------------统计结果--------------------------------\n")
printf("总分最高者:\t%s %d分\n",pt->data.name,pt->data.totle)
printf("平均分最高者:\t%s %d分\n",pa->data.name,pa->data.ave)
printf("英语最高者:\t%s %d分\n",pe->data.name,pe->data.egrade)
printf("数学最高者:\t%s %d分\n",pm->data.name,pm->data.mgrade)
printf("c语言最高者:\t%s %d分\n",pc->data.name,pc->data.cgrade)
printstart()
}
void Sort(Link l)
{
Link ll
Node *p,*rr,*s
ll=(Link)malloc(sizeof(Node))/* 用于做新的连表 */
ll->next=NULL
if(l->next==NULL)
{
printf("\n=====>提示:没有资料可以排序!\n")
return
}
p=l->next
while(p)
{
s=(Node*)malloc(sizeof(Node))/* 新建接点用于保存信息 */
s->data=p->data
s->next=NULL
rr=ll
while(rr->next!=NULL &&rr->next->data.totle>=p->data.totle)
rr=rr->next
if(rr->next==NULL)
rr->next=s
else
{
s->next=rr->next
rr->next=s
}
p=p->next
}
free(l)
l->next=ll->next
printf("\n=====>提示:排序已经完成!\n")
}
void Save(Link l)
{
FILE* fp
Node *p
int flag=1,count=0
fp=fopen("c:\\student","wb")
if(fp==NULL)
{
printf("\n=====>提示:重新打开文件时发生错误!\n")
exit(1)
}
p=l->next
while(p)
{
if(fwrite(p,sizeof(Node),1,fp)==1)
{
p=p->next
count++
}
else
{
flag=0
break
}
}
if(flag)
{
printf("\n=====>提示:文件保存成功.(有%d条记录已经保存.)\n",count)
shoudsave=0
}
fclose(fp)
}
void main()
{
Link l/* 连表 */
FILE *fp/* 文件指针 */
int sel
char ch
char jian
int count=0
Node *p,*r
printf("\t\t\t\t学生成绩管理系统\n\t\t\t\t-------福建农业职业学院计应0501 黄欢(32号)\n")
l=(Node*)malloc(sizeof(Node))
l->next=NULL
r=l
fp=fopen("C:\\student","rb")
if(fp==NULL)
{
printf("\n=====>提示:文件还不存在,是否创建?(y/n)\n")
scanf("%c",&jian)
if(jian=='y'||jian=='Y')
fp=fopen("C:\\student","wb")
else
exit(0)
}
printf("\n=====>提示:文件已经打开,正在导入记录......\n")
while(!feof(fp))
{
p=(Node*)malloc(sizeof(Node))
if(fread(p,sizeof(Node),1,fp)) /* 将文件的内容放入接点中 */
{
p->next=NULL
r->next=p
r=p/* 将该接点挂入连中 */
count++
}
}
fclose(fp)/* 关闭文件 */
printf("\n=====>提示:记录导入完毕,共导入%d条记录.\n",count)
while(1)
{
menu()
printf("请你选择 *** 作:")
scanf("%d",&sel)
if(sel==0)
{
if(shoudsave==1)
{ getchar()
printf("\n=====>提示:资料已经改动,是否将改动保存到文件中(y/n)?\n")
scanf("%c",&ch)
if(ch=='y'||ch=='Y')
Save(l)
}
printf("\n=====>提示:你已经退出系统,再见!\n")
break
}
switch(sel)
{
case 1:Add(l)break/* 增加学生 */
case 2:Del(l)break/* 删除学生 */
case 3:Qur(l)break/* 查询学生 */
case 4:Modify(l)break/* 修改学生 */
case 5:Save(l)break/* 保存学生 */
case 9:printf("\t\t\t==========帮助信息==========\n")break
default: Wrong()getchar()break
}
}
}
/* */
/*
学生成绩管理程序
编制一个统计学生考试分数的管理程序。
设学生成绩已以一个学生一个记录的形式存储在文件中,
每位学生记录包含的信息有:姓名,学号和各门功课的成绩。
程序具有以下几项功能:求出各门课程的总分,平均分,按姓名,
按学号寻找其记录并显示,浏览全部学生成绩和按总分由高到低显示学生信息等。
*/
#include <stdio.h>
#define SWN 3 /* 课程数 */
#define NAMELEN 20 /* 姓名最大字符数 */
#define CODELEN 10 /* 学号最大字符数 */
#define FNAMELEN 80 /* 文件名最大字符数 */
#define BUFLEN 80 /* 缓冲区最大字符数 */
/* 课程名称表 */
char schoolwork[SWN][NAMELEN+1] = {"Chinese","Mathematic","English"}
struct record
{
char name[NAMELEN+1]/* 姓名 */
char code[CODELEN+1]/* 学号 */
int marks[SWN]/* 各课程成绩 */
int total/* 总分 */
}stu
struct node
{
char name[NAMELEN+1]/* 姓名 */
char code[CODELEN+1]/* 学号 */
int marks[SWN]/* 各课程成绩 */
int total/* 总分 */
struct node *next/* 后续表元指针 */
}*head/* 链表首指针 */
int total[SWN]/* 各课程总分 */
FILE *stfpt/* 文件指针 */
char stuf[FNAMELEN]/* 文件名 */
/* 从指定文件读入一个记录 */
int readrecord(FILE *fpt,struct record *rpt)
{
char buf[BUFLEN]
int i
if(fscanf(fpt,"%s",buf)!=1)
return 0/* 文件结束 */
strncpy(rpt->name,buf,NAMELEN)
fscanf(fpt,"%s",buf)
strncpy(rpt->code,buf,CODELEN)
for(i=0i<SWNi++)
fscanf(fpt,"%d",&rpt->marks[i])
for(rpt->total=0,i=0i<SWNi++)
rpt->total+=rpt->marks[i]
return 1
}
/* 对指定文件写入一个记录 */
writerecord(FILE *fpt,struct record *rpt)
{
int i
fprintf(fpt,"%s\n",rpt->name)
fprintf(fpt,"%s\n",rpt->code)
for(i=0i<SWNi++)
fprintf(fpt,"%d\n",rpt->marks[i])
return
}
/* 显示学生记录 */
displaystu(struct record *rpt)
{
int i
printf("\nName : %s\n",rpt->name)
printf("Code : %s\n",rpt->code)
printf("Marks :\n")
for(i=0i<SWNi++)
printf(" %-15s : %4d\n",schoolwork[i],rpt->marks[i])
printf("Total : %4d\n",rpt->total)
}
/* 计算各单科总分 */
int totalmark(char *fname)
{
FILE *fp
struct record s
int count,i
if((fp=fopen(fname,"r"))==NULL)
{
printf("Can't open file %s.\n",fname)
return 0
}
for(i=0i<SWNi++)
total[i]=0
count=0
while(readrecord(fp,&s)!=0)
{
for(i=0i<SWNi++)
total[i]+=s.marks[i]
count++
}
fclose(fp)
return count/* 返回记录数 */
}
/* 列表显示学生信息 */
void liststu(char *fname)
{
FILE *fp
struct record s
if((fp=fopen(fname,"r"))==NULL)
{
printf("Can't open file %s.\n",fname)
return
}
while(readrecord(fp,&s)!=0)
{
displaystu(&s)
printf("\n Press ENTER to continue...\n")
while(getchar()!='\n')
}
fclose(fp)
return
}
/* 构造链表 */
struct node *makelist(char *fname)
{
FILE *fp
struct record s
struct node *p,*u,*v,*h
int i
if((fp=fopen(fname,"r"))==NULL)
{
printf("Can't open file %s.\n",fname)
return NULL
}
h=NULL
p=(struct node *)malloc(sizeof(struct node))
while(readrecord(fp,(struct record *)p)!=0)
{
v=h
while(v&&p->total<=v->total)
{
u=v
v=v->next
}
if(v==h)
h=p
else
u->next=p
p->next=v
p=(struct node *)malloc(sizeof(struct node))
}
free(p)
fclose(fp)
return h
}
/* 顺序显示链表各表元 */
void displaylist(struct node *h)
{
while(h!=NULL)
{
displaystu((struct record *)h)
printf("\n Press ENTER to continue...\n")
while(getchar()!='\n')
h=h->next
}
return
}
/* 按学生姓名查找学生记录 */
int retrievebyn(char *fname, char *key)
{
FILE *fp
int c
struct record s
if((fp=fopen(fname,"r"))==NULL)
{
printf("Can't open file %s.\n",fname)
return 0
}
c=0
while(readrecord(fp,&s)!=0)
{
if(strcmp(s.name,key)==0)
{
displaystu(&s)
c++
}
}
fclose(fp)
if(c==0)
printf("The student %s is not in the file %s.\n",key,fname)
return 1
}
/* 按学生学号查找学生记录 */
int retrievebyc(char *fname, char *key)
{
FILE *fp
int c
struct record s
if((fp=fopen(fname,"r"))==NULL)
{
printf("Can't open file %s.\n",fname)
return 0
}
c=0
while(readrecord(fp,&s)!=0)
{
if(strcmp(s.code,key)==0)
{
displaystu(&s)
c++
break
}
}
fclose(fp)
if(c==0)
printf("The student %s is not in the file %s.\n",key,fname)
return 1
}
main()
{
int i,j,n
char c
char buf[BUFLEN]
FILE *fp
struct record s
clrscr()
printf("Please input the students marks record file's name: ")
scanf("%s",stuf)
if((fp=fopen(stuf,"r"))==NULL)
{
printf("The file %s doesn't exit, do you want to creat it? (Y/N) ",stuf)
getchar()
c=getchar()
if(c=='Y'||c=='y')
{
fp=fopen(stuf,"w")
printf("Please input the record number you want to write to the file: ")
scanf("%d",&n)
for(i=0i<ni++)
{
printf("Input the student's name: ")
scanf("%s",&s.name)
printf("Input the student's code: ")
scanf("%s",&s.code)
for(j=0j<SWNj++)
{
printf("Input the %s mark: ",schoolwork[j])
scanf("%d",&s.marks[j])
}
writerecord(fp,&s)
}
fclose(fp)
}
}
fclose(fp)
getchar()
/*clrscr()*/
puts("Now you can input a command to manage the records.")
puts("m : mean of the marks.")
puts("t : total of the marks.")
puts("n : search record by student's name.")
puts("c : search record by student's code.")
puts("l : list all the records.")
puts("s : sort and list the records by the total.")
puts("q : quit!")
while(1)
{
puts("Please input command:")
scanf(" %c",&c)/* 输入选择命令 */
if(c=='q'||c=='Q')
{
puts("\n Thank you for your using.")
break/* q,结束程序运行 */
}
switch(c)
{
case 'm': /* 计算平均分 */
case 'M':
if((n=totalmark(stuf))==0)
{
puts("Error!")
break
}
printf("\n")
for(i=0i<SWNi++)
printf("%-15s's average is: %.2f.\n",schoolwork[i],(float)total[i]/n)
break
case 't': /* 计算总分 */
case 'T':
if((n=totalmark(stuf))==0)
{
puts("Error!")
break
}
printf("\n")
for(i=0i<SWNi++)
printf("%-15s's total mark is: %d.\n",schoolwork[i],total[i])
break
case 'n': /* 按学生的姓名寻找记录 */
case 'N':
printf("Please input the student's name you want to search: ")
scanf("%s",buf)
retrievebyn(stuf,buf)
break
case 'c': /* 按学生的学号寻找记录 */
case 'C':
printf("Please input the student's code you want to search: ")
scanf("%s",buf)
retrievebyc(stuf,buf)
break
case 'l': /* 列出所有学生记录 */
case 'L':
liststu(stuf)
break
case 's': /* 按总分从高到低排列显示 */
case 'S':
if((head=makelist(stuf))!=NULL)
displaylist(head)
break
default: break
}
}
}
#include<stdio.h>02.struct student
03.{
04.
char xuehao[20]
05.
char name[20]
06.
char sex[3]
07.
double score[3]
08.
double ave
09.
double s
10.}
11.void main()
12.{
13.
struct student stu[1]
14.
int i
15.
scanf("%s %s %s",stu[0].xuehao,stu[0].name,stu[0].sex)
16.
stu[0].s=0
17.
for(i=0i<3i++)
18.
{
19.
scanf("%lf",&stu[0].score[i])
20.
stu[0].s+=stu[0].score[i]
21.
}
22.
stu[0].ave=stu[0].s/3
23.
24.
25.
printf("%s",stu[0].xuehao)
26.
printf(" %s",stu[0].name)
27.
printf(" %s",stu[0].sex)
28.
for(i=0i<3i++)
29.
{
30.
printf(" %.2f",stu[0].score[i])
31.
}
32.
printf(" %.2f %.2f\n",stu[0].ave,stu[0].s)
33.}
按照这个就行了
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)