当前位置: 首页 > news >正文

网站建设管理经验做法宜春静态管理

网站建设管理经验做法,宜春静态管理,价格低怎么说,网站建设及代运营合同学生成绩管理程序 实例说明 编制一个统计存储在文件中的学生考试分数的管理程序。设学生成绩以一个学生一条记录的 形式存储在文件中#xff0c;每个学生记录包含的信息有姓名、学号和各门功课的成绩。要求编制具有以 下几项功能的程序#xff1a;求出各门课程的总分#…学生成绩管理程序 实例说明 编制一个统计存储在文件中的学生考试分数的管理程序。设学生成绩以一个学生一条记录的 形式存储在文件中每个学生记录包含的信息有姓名、学号和各门功课的成绩。要求编制具有以 下几项功能的程序求出各门课程的总分平均分、按姓名按学号寻找其记录并显示浏览全 部学生成绩和按总分由高到低显示学生信息等。 程序运行结果 输入 l 命令后的结果 输入 s 命令后的结果 按姓名和学号查找记录的结果 计算平均分和总分 实例解析 设每位学生学习语文、数学和英语 3 门课程主程序输入文件名之后进入接受命令、执行 命令处理程序的循环。 按问题的要求共设 5 条命令求各门课程的总分、求各门课程的平均分、按学生名字寻找其 信息、按学号寻找其信息、结束命令。 为求各门课程的总分从文件逐一读出学生记录累计各门课程的分数待文件处理完即可 得到各门课程的总分。为求各门课程的平均分从文件逐一读出学生记录累计各门课程的分数 并统计学生人数待文件处理完毕将得到的各门课程的总分除以人数就得到各门课程的平均分。 按学生名字寻找学生信息的处理首先要求输入待寻找学生的名字顺序读入学生记录凡名字 与待寻找学生相同的记录都在屏幕上显示直到文件结束。按学生学号寻找学生信息的处理首 先要求输入待寻找学生的学号顺序读入学生记录发现有学号与待寻找学生相同的记录就在屏 幕上显示并结束处理。浏览学生全部成绩顺序读入学生记录并在屏幕上显示直到文件结 束。按总分由高到低显示学生信息首先顺序读入学生记录并构造一个有序链表然后顺序显示 链表上的各元素。 程序代码 #include stdio.h #define SWN 3 /* 课程数 */ #define NAMELEN 20 /* 姓名最大字符数 */ #define CODELEN 10 /* 学号最大字符数 */ #define FNAMELEN 80 /* 文件名最大字符数 */ #define BUFLEN 80 /* 缓冲区最大字符数 */ /* 课程名称表 */ char schoolwork[SWN][NAMELEN1] {Chinese,Mathematic,English}; struct record { char name[NAMELEN1]; /* 姓名 */ char code[CODELEN1]; /* 学号 */ int marks[SWN]; /* 各课程成绩 */ int total; /* 总分 */ }stu; struct node { char name[NAMELEN1]; /* 姓名 */ char code[CODELEN1]; /* 学号 */ 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(i0;iSWN;i) fscanf(fpt,%d,rpt-marks[i]); for(rpt-total0,i0;iSWN;i) rpt-totalrpt-marks[i]; return 1; } /* 对指定文件写入一条记录 */ void writerecord(FILE *fpt,struct record *rpt) { int i; fprintf(fpt,%s\n,rpt-name); fprintf(fpt,%s\n,rpt-code); for(i0;iSWN;i) fprintf(fpt,%d\n,rpt-marks[i]); return ; } /* 显示学生记录 */ void displaystu(struct record *rpt) { int i; printf(\nName : %s\n,rpt-name); printf(Code : %s\n,rpt-code); printf(Marks :\n); for(i0;iSWN;i) 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((fpfopen(fname,r))NULL) { printf(Cant open file %s.\n,fname); return 0; } for(i0;iSWN;i) total[i]0; count0; while(readrecord(fp,s)!0) { for(i0;iSWN;i) total[i]s.marks[i]; count; } fclose(fp); return count; /* 返回记录数 */ } /* 列表显示学生信息 */ void liststu(char *fname) { FILE *fp; struct record s; if((fpfopen(fname,r))NULL) {printf(Cant 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((fpfopen(fname,r))NULL) { printf(Cant open file %s.\n,fname); return NULL; } hNULL; p(struct node *)malloc(sizeof(struct node)); while(readrecord(fp,(struct record *)p)!0) { vh; while(vp-totalv-total) { uv; vv-next; } if(vh) hp; else u-nextp; p-nextv; 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); hh-next; } return; } /* 按学生姓名查找学生记录 */ int retrievebyn(char *fname, char *key) { FILE *fp; int c; struct record s; if((fpfopen(fname,r))NULL) { printf(Cant open file %s.\n,fname); return 0; } c0; while(readrecord(fp,s)!0) { if(strcmp(s.name,key)0) { displaystu(s); c; } } fclose(fp); if(c0) 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((fpfopen(fname,r))NULL) { printf(Cant open file %s.\n,fname); return 0; } c0; while(readrecord(fp,s)!0) { if(strcmp(s.code,key)0) { displaystu(s); c; break; } } fclose(fp); if(c0)printf(The student %s is not in the file %s.\n,key,fname); return 1; } /*示意程序*/ int main() {int i,j,n; char c; char buf[BUFLEN]; FILE *fp; struct record s; clrscr(); printf(Please input the students marks record files name: ); scanf(%s,stuf); if((fpfopen(stuf,r))NULL) { printf(The file %s doesnt exit, do you want to creat it? (Y/N) ,stuf); getchar(); cgetchar(); if(cY||cy) { fpfopen(stuf,w); printf(Please input the record number you want to write to the file: ); scanf(%d,n); for(i0;in;i) { printf(Input the students name: ); scanf(%s,s.name); printf(Input the students code: ); scanf(%s,s.code); for(j0;jSWN;j) { 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 students name.); puts(c : search record by students 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(cq||cQ) { puts(\n Thank you for your using.); break; /* q结束程序运行 */ } switch(c) { case m: /* 计算平均分 */ case M: if((ntotalmark(stuf))0) { puts(Error!); break; } printf(\n); for(i0;iSWN;i) printf(%-15ss average is: %.2f.\n,schoolwork[i], (float) total[i]/n); break; case t: /* 计算总分 */ case T: if((ntotalmark(stuf))0) { puts(Error!); break; } printf(\n); for(i0;iSWN;i) printf(%-15ss total mark is: %d.\n,schoolwork[i], total[i]); break; case n: /* 按学生的姓名寻找记录 */ case N: printf(Please input the students name you want to search: );scanf(%s,buf); retrievebyn(stuf,buf); break; case c: /* 按学生的学号寻找记录 */ case C: printf(Please input the students code you want to search: );scanf(%s,buf); retrievebyc(stuf,buf); break; case l: /* 列出所有学生记录 */ case L: liststu(stuf); break; case s: /* 按总分从高到低排列显示 */ case S: if((headmakelist(stuf))!NULL) displaylist(head); break; default: break;} } return 0; }归纳注释 本程序除为每个处理功能编写相应的函数外另外编写从文件读学生记录的函数、写记录到 文件和显示一个学生记录的函数从而简化编程。
http://www.hkea.cn/news/14395758/

相关文章:

  • 医院网站内链优化做网站推广每天加班
  • 腾讯云做网站教程企业网站宽度给多少
  • 公司网站建设北京求个没封的a站yw1129cm
  • 广州网站建设十年乐云seo大宗商品交易平台
  • 营销型类型网站有哪些类型app软件开发的费用设计
  • 学院网站制度建设网站建设业务
  • 化妆品网站推广策划书重庆手机网站推广方法
  • 免费平面设计模板网站有哪些设计好看的企业官网
  • j建网站wordpress表
  • 江阴做公司网站有哪些中企动力建设的网站如何修改
  • 临沂培训学校网站建设做餐饮网站价格
  • php中网站不同模板后台逻辑代码怎么管理wordpress错误代码500
  • 环境设计案例网站深圳网站关键词
  • 网站换空间 site网站中文名称注册
  • 网站开发的网站解释seo网站推广
  • 拼多多网站策划书客户软件管理系统
  • 网站制作长春中文域名价格
  • 担路网做网站多少钱建设租房信息网站
  • 西安网站制作顶尖如何配置iis网站
  • 网站获取qq号码 原理企业网站开发合同
  • 一个手机网站wordpress 即时通迅
  • 做恒生指数看什么网站专业网店推广
  • 家装设计网站排行榜前十名建设网站能赚钱吗
  • 做网站在什么地方找广州定制网站建设方案书
  • 常德网站建公司体系建设的意义
  • 织梦做的网站打开不是seo策略有哪些
  • 手机网站大全免费网站建设招标提问
  • 旅游网站栏目建设网站设计与制作专业
  • 网站建设公司找客户wordpress手机站如何做
  • 长春微建站是哪个平台的网站设计与网页配色实例精讲