C语言编程—学生成绩查询系统!紧急!!!

C语言编程—学生成绩查询系统!紧急!!!,第1张

这个是我自己做的类式的,你可以按自己的要求改下·不难的和你的差不多,给分哦

#include<stdlib.h>

#include<stdio.h>

#include<string.h>

#include<conio.h>

#define N 10

/*****定义结构体*****/

typedef struct students/*标记为students*/

{

char num[10] /*学生学号*/

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.}

按照这个就行了


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9727013.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存