学生信息管理系统c语言版源代码样本.doc
《学生信息管理系统c语言版源代码样本.doc》由会员分享,可在线阅读,更多相关《学生信息管理系统c语言版源代码样本.doc(32页珍藏版)》请在咨信网上搜索。
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <conio.h> #define N 1000 typedef struct student { int number; char name[20]; int grade; int gaoshu; int yingyu; int jisuanji; int sum; }STUDENT; STUDENT student[N]; int shuliang=0; void menu(); void fhzjm() { char biaozhi[20]; printf("\n"); printf("还需要操作么?如果需要操作请输入:yes,否则请输入:no\n"); scanf("%s",biaozhi); if(strcmp(biaozhi,"yes")==0) { menu(); } else if(strcmp(biaozhi,"no")==0) exit(0); else { printf("请输入对的字符,谢谢!\n"); fhzjm(); } } void DengJi() { int rs; int i,k=1; system("CLS"); printf("请输入需要输入几种学生信息:"); scanf("%d",&rs); for(i=shuliang;i<shuliang+rs;i++,k++) { printf("请输入第%d个学生学号:",k); scanf("%d",&student[i].number); printf("请输入学生姓名:"); scanf("%s",student[i].name); printf("请输入学生3门课成绩:"); printf("请输入第1门课成绩:"); scanf("%d",&student[i].gaoshu); printf("请输入第2门课成绩:"); scanf("%d",&student[i].yingyu); printf("请输入第3门课成绩:"); scanf("%d",&student[i].jisuanji); } shuliang=shuliang+rs; fhzjm(); } void ShanChu() { char shanchuinfo[10]; system("CLS"); printf("删除所有学生信息请输入\"all\",删除指定学号学生信息请输入\"one\"\n"); scanf("%s",shanchuinfo); if(strcmp(shanchuinfo,"all")==0) { int j; printf("你删除学生信息如下:\n"); printf("-----------学号-------------姓名-------------高数--------------英语--------------计算机\t\n"); for(j=0;j<shuliang;j++) printf("----%d-------%s-------%d-------%d-------%d\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].jisuanji); shuliang=0; printf("删除成功\n\n"); } else if(strcmp(shanchuinfo,"one")==0) { struct student *p=NULL; int choice; int i,j,k=0; printf("请输入你要删除人学号:"); scanf("%d",&choice); for(i=0;i<shuliang;i++) { if(choice==student[i].number) { k=1;j=i;break; } } if(k) { if(shuliang==1) { p=&student[0]; free(p); shuliang=0; } else { for(i=j;i<shuliang;i++) { student[i]=student[i+1]; } shuliang=shuliang-1; } printf("删除成功\n\n"); } else { printf("输入数据错误!\n"); } } fhzjm(); } void LiuLan() { int i; system("CLS"); if(shuliang==0) { printf("系统里面没有任何学生信息!\n"); } else { for(i=0;i<shuliang;i++) { printf("第%d个学生学号为:%d\n",i+1,student[i].number); printf("第%d个学生姓名为:%s\n",i+1,student[i].name); printf("第%d个学生第一门课成绩为:%d\n",i+1,student[i].gaoshu); printf("第%d个学生第二门课成绩为:%d\n",i+1,student[i].yingyu); printf("第%d个学生第三门课成绩为:%d\n",i+1,student[i].jisuanji); student[i].sum=student[i].gaoshu+student[i].yingyu+student[i].jisuanji; printf("第%d个学生总成绩为:%d\n",i+1,student[i].sum); } } fhzjm(); } void ChaZhao() { int xx; char choice,yy[20]; int i,j,k=0; system("CLS"); if(shuliang==0) { printf("系统里面没有任何学生信息!\n"); fhzjm(); } printf("三种查找方式:学号,姓名,成绩\n"); printf("如果按学号查找请输1,如果按姓名查找请输2,如果按成绩查找请输3\n"); printf("请输入您查找方式:"); scanf("%s",&choice); if(choice=='1') { printf("请输入需要查找学生学号:"); scanf("%d",&xx); printf("您所查找学生信息为:\n"); printf("----学号----姓名----高数成绩----英语成绩----计算机成绩----\t\n"); for(i=0;i<shuliang;i++) { if(xx==student[i].number) { j=i;k=1; printf("----%d-------%s-------%d-------%d-------%d----\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].yingyu,student[i].jisuanji); } } if(k==0) printf("输入信息有误:\n"); } else if(choice=='2') { printf("请输入需要查找学生姓名:\n"); scanf("%s",yy); printf("您所查找学生信息为:\n"); printf("----学号----姓名----高数成绩----英语成绩----计算机成绩----\t\n"); for(i=0;i<shuliang;i++) { if(strcmp(yy,student[i].name)==0) { j=i;k=1; printf("----%d-------%s-------%d-------%d-------%d----\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].yingyu,student[j].jisuanji); } } if(k==0) printf("输入信息有误:\n"); } else if(choice=='3') { printf("请输入需要查找学生成绩:\n"); scanf("%d",&xx); printf("您所查找学生信息为:\n"); printf("----学号----姓名----高数----英语----计算机----\t\n"); for(i=0;i<shuliang;i++) { if(xx==student[i].grade) { j=i;k=1; printf("----%d-------%s-------%d-------%d-------%d----\t\n",student[j].number,student[j].name,student[j].gaoshu,student[j].yingyu,student[i].jisuanji); } } if(k==0) printf("输入信息有误:\n"); } fhzjm(); } void PaiXu() { struct student *p1[N],**p2,*temp; int i,j; system("CLS"); p2=p1; for( i=0;i<shuliang;i++) { p1[i]=student+i; } for( i=0;i<shuliang;i++) { for( j=i+1;j<shuliang;j++) { if((*(p2+i))->sum<(*(p2+j))->sum) {temp=*(p2+i);*(p2+i)=*(p2+j);*(p2+j)=temp;} } } printf("按照总成绩排序之后信息为:\n"); printf("----学号----姓名----总成绩----\t\n"); for( i=0;i<shuliang;i++) { student[i].sum=student[i].gaoshu+student[i].yingyu+student[i].jisuanji; printf("----%d-----%s----%d-----\n",(*(p2+i))->number,(*(p2+i))->name,(*(p2+i))->sum); } fhzjm(); } void CunChu() { int i; FILE *rs; if((rs=fopen("student.txt","w"))==NULL) { printf("not open"); exit(0); } for(i=0;i<shuliang;i++) { fwrite(&student[i],sizeof(student[i]),1,rs); } if(ferror(rs)) { fclose(rs); perror("写文献失败!\n"); return; } printf("存储文献成功!\n"); fclose(rs); fhzjm(); } void DaoChu() { struct student t; int i=0; FILE* fp = fopen("student.txt","r"); shuliang=0; if(NULL==fp) { perror("读取文献打开失败!\n"); return; } memset(student,0x0,sizeof(student)); while(1) { fread(&t,sizeof(t),1,fp); if(ferror(fp)) { fclose(fp); perror("读文献过程失败!\n"); return; } if(feof(fp)) { break; } student[i]=t; i++; } fclose(fp); shuliang=i; printf("导出文献成功!\n"); fhzjm(); } void menu() { int n=0; system("CLS"); printf(" 学生信息管理系统\n"); printf(" 作者:陈椿\n"); printf("-------------------MENU-----------------\n"); printf(" 1.登记学生信息\n"); printf(" 2.删除学生信息\n"); printf(" 3.浏览所有已经登记学生\n"); printf(" 4.查找\n"); printf(" 4.1按学号查找\n"); printf(" 4.2按姓名查找\n"); printf(" 4.3按成绩查找\n"); printf(" 5.依照总成绩排序\n"); printf(" 6.存储到文献\n"); printf(" 7.从文献导出\n"); printf(" 8.退出系统\n"); a: printf(" 请选取:"); scanf("%d",&n); switch (n) { case 1: DengJi();break; case 2: ShanChu();break; case 3: LiuLan();break; case 4: ChaZhao();break; case 5: PaiXu();break; case 6: CunChu();break; case 7: DaoChu();break; case 8: exit(0);break; default: { printf("请输入1-8之间数字,谢谢!\n"); goto a; } } } main() { menu(); }- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学生 信息管理 系统 语言版 源代码 样本
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文